Nginx proxy_redirect の使用方法の詳細な説明

Nginx proxy_redirect の使用方法の詳細な説明

今日、Apache の nginx リバース プロキシを実行していたときに、ちょっとした問題に遭遇しました。バックエンドの Apache が使用するポートが 8080 であることが判明しました。リバース プロキシを通過後、Wireshark を使用してパケットをキャプチャしたところ、location ヘッダー フィールドの値が http://192.168.1.154:8080/wuman/ であることがわかりました。これがクライアントに返される場合、間違いなく許可されていません。見た目が不自然ですし、Apache の特定の情報も公開されます。

したがって、ここでは、nginx の proxy_redirect を使用して、プロキシ サーバーによって返される応答ヘッダー内の location ヘッダー フィールドと refresh ヘッダー フィールドの値の変更を指定します。

以下はnginxの設定ドキュメントからの抜粋です。

サーバー{
 聞く 80;
 サーバー名 www.boke.com;
 位置 / {
  プロキシパス http://192.168.1.154:8080;
  proxy_redirect オフ;
 }
 }

この時点で、curlを使用して結果を表示します。

[root@localhost nginx]# curl -I http://www.boke.com/wuman
HTTP/1.1 301 永久に移動
サーバー: nginx
日付: 2015 年 12 月 24 日 (木) 12:02:00 GMT
コンテンツタイプ: text/html; 文字セット=iso-8859-1
接続: キープアライブ
場所: http://192.168.1.154:8080/wuman/

ここで、location はバックエンド サーバーの実際のアドレスとポートを含む応答ヘッダー情報です。これは実際の行では許可されていないため、ここでは proxy_redirect を介してプロキシ サーバーの応答ヘッダーの location フィールドを変更し、クライアントに返すことを計画しています。

サーバー{
 聞く 80;
 サーバー名 www.boke.com;
 位置 / {
  プロキシパス http://192.168.1.154:8080;
  プロキシリダイレクト http://192.168.1.154:8080/wuman/ http://www.boke.com/wuman/;
 }

サーバー{
 聞く 80;
 サーバー名 www.boke.com;
 位置 / {
  プロキシパス http://192.168.1.154:8080;
  プロキシリダイレクト ~^http://192.168.1.154:8080(.*) http://www.boke.com$1;
 }

次にcurlは返された結果をチェックします

[root@localhost nginx]# curl -I http://www.boke.com/wuman
HTTP/1.1 301 永久に移動
サーバー: nginx
日付: 2015 年 12 月 24 日 (木) 12:08:34 GMT
コンテンツタイプ: text/html; 文字セット=iso-8859-1
接続: キープアライブ
場所: http://www.boke.com/wuman/

この時点で、場所を確認することが私たちが望む結果になりました。 この時点で、301の置き換えにより新しいページにリダイレクトされました。

ソース:

プロキシリダイレクト

構文: proxy_redirect [ デフォルト|オフ|リダイレクト置換 ]

デフォルト値: proxy_redirect default

使用フィールド: http、サーバー、場所

プロキシされたサーバーから送信された応答ヘッダーの「Location」フィールドと「Refresh」フィールドを変更する必要がある場合は、このコマンドを使用して設定できます。

プロキシ サーバーによって返される Location フィールドが http://localhost:8000/two/some/uri/ であると仮定します。

この指示:

proxy_redirect http://localhost:8000/two/ http://frontend/one/;

Location フィールドを http://frontend/one/some/uri/ に書き換えます。

置換フィールドにサーバー名を入力する必要はありません。

proxy_redirect http://localhost:8000/two/ /;

これにより、80 以外のポートからの場合でも、サーバーのベース名とポートが使用されます。

「default」パラメータが使用される場合、location および proxy_pass パラメータの設定に基づいて決定されます。

たとえば、次の 2 つの構成は同等です。

場所 / 1 / {
 proxy_pass http://upstream:port/two/; 
 proxy_redirect デフォルト;
}
場所 / 1 / {
 proxy_pass http://upstream:port/two/; 
 proxy_redirect http://upstream:port/two/ /one/;
}

ディレクティブで使用できる変数はいくつかあります。

proxy_redirect http://localhost:8000/ http://$host:$server_port/;

この指示は繰り返されることがあります:

proxy_redirect デフォルト;
proxy_redirect http://localhost:8000//; proxy_redirect; /;

パラメータ off は、このフィールド内のすべての proxy_redirect ディレクティブを無効にします。

proxy_redirect オフ;
proxy_redirect デフォルト;
proxy_redirect http://localhost:8000/ /; proxy_redirect ; /;

プロキシされたサーバーによって発行された相対リダイレクトにホスト名を追加するには、このディレクティブを使用します。

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • Nginx でグレースケールリリースを実装する 3 つの方法の概要
  • Asp.Net Core の公開と展開の詳細な説明 (MacOS + Linux + Nginx)
  • nginx がリリースしたばかりの JavaScript 機能、nginScript の簡単な分析
  • Nginxのアクセスボリューム制御の詳細な説明
  • nginx を使用したプロキシ サーバーの設定
  • Docker コンテナのデプロイの試み - マルチコンテナ通信 (node+mongoDB+nginx)
  • 指定したディレクトリに nginx をインストールする方法の例
  • Linux システムで IPv6 をサポートするように Nginx を設定する方法
  • VueとNginxをベースにしたフロントエンドとバックエンドのデプロイメントチュートリアルの詳細な説明
  • nginx を使用してカナリアリリースをシミュレートする方法

<<:  Linux での MySQL 5.7.18 yum のアンインストールからインストールまでのプロセスの図

>>:  jQuery ツリービュー ツリー構造アプリケーション

推薦する

フォームの「Enter」、「Submit」、「Enter != Submit」を削除する方法

「Enter != Submit」問題を実装するには、通常、「ボタンの種類」と「入力ボックスの数」か...

echarts ワードクラウドチャートを使用した Vue の実践記録

echartsワードクラウドはechartsの拡張版ですhttps://echarts.apache...

クロスドメイン js フロントエンドの 8 つの実装ソリューション

目次1. jsonp クロスドメイン2. document.domain + iframe クロスド...

Linux で圧縮ファイルの内容を表示する 10 の方法 (要約)

一般的に、アーカイブされたファイルや圧縮されたファイルの内容を表示するには、まず解凍してから表示する...

MySQLにおけるトランザクションの永続性実装原理の詳細な説明

序文データベース トランザクションに関して言えば、トランザクションの ACID 特性、分離レベル、解...

HTML リスト タグ dl、ul、ol の使用例

コードをコピーコードは次のとおりです。 <!--リストタグ: <dl>: 階層リス...

Linux (CentOS) システムで MySQL データベース ディレクトリの場所を変更する方法

CentOS システムで MySQL データベース ディレクトリの場所を変更する方法1. まず、My...

HTML テーブルタグチュートリアル (12): 境界線スタイル属性 FRAME

FRAME プロパティを使用して、表の境界線のスタイル タイプを制御します。基本的な構文<T...

HTML サブタグと sup タグ

今日はあまり使わないHTMLタグ「subタグ」と「supタグ」を紹介します。定義と使用法: <...

Nginx シグナル制御

Nginx の紹介Nginx は、高性能な HTTP およびリバース プロキシ サーバーであり、IM...

誰もが知っておくべきウェブサイトのユーザビリティに関する 10 のヒント

これ以上時間を無駄にせず、早速本題に入りましょう。 1. ロゴに代替テキストを追加するこれには 2 ...

JavaScriptのvar let constの違いは何ですか?

目次1. 繰り返し宣言1.1 変数1.2 しましょう1.3 定数2. 可変プロモーション2.1 変数...

Echatsチャートの大画面適応を実装する方法

目次説明する成し遂げるプロジェクトのディレクトリ構造は次のとおりです。効果図は以下のとおりです要約す...

RGBカラーテーブルコレクション

RGBカラーテーブル色英語名RGB 16色雪255 250 250 #FFFAFAゴーストホワイト2...