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 ツリービュー ツリー構造アプリケーション

推薦する

WeChat 8.0の爆発的な特殊効果を実現するために300行以上のCSSコードが必要

WeChat 8.0 アップデートの主な特徴は、アニメーション絵文字のサポートです。送信するメッセー...

スプライトとフォントアイコンを実装するためのCSS

スプライト:以前は、各画像リソースは独立した画像でした。ブラウザが Web サイト内のさまざまな W...

Dockerイメージのローカル移行の実装

最近 Docker を勉強しているのですが、よく問題に遭遇します。Docker イメージをダウンロー...

CSS を使用して ul と li の水平配置を実現する 2 つの方法

li はブロックレベル要素であり、デフォルトで 1 行を占めるため、水平方向の配置を実現する場合は、...

Centos 7 システムの Tomcat サーバーの詳細な分析

目次1. tomcatの起源1. Tomcat アプリケーションのシナリオ2. Tomcatに必要な...

dockerコンテナがIP経由でホストマシンにアクセスできない問題を解決する方法の詳細な説明

問題の起源docker を使用する場合、残念ながら docker コンテナ内のホストのポート 80 ...

nginx を介してローカルでリバースプロキシを構成するプロセス全体

序文Nginx は、イベント駆動型の非同期非ブロッキング処理フレームワークを使用する軽量 HTTP ...

HTML 要素の高さ、offsetHeight、clientHeight、scrollTop などの詳細な説明。

要素に関するいくつかの属性フロントエンドの日常的な開発では、一部のページのプロパティを取得または監視...

jsはFileReaderを使用してローカルファイルまたはBLOBを読み取ります

目次FileReaderはローカルファイルまたはBLOBを読み取ります1. FileReaderの使...

Vue2 キューブUI 時間セレクターの詳細な説明

目次序文1. 需要と効果必要効果2. コードの実装index.vue(html)日付方法テスト結果3...

Vue の大容量ファイルアップロードとブレークポイント再開アップロードの実装

目次ファイルアップロードのための2つのソリューションファイルストリーム(フォームデータ)に基づくクラ...

NginxにLuaモジュールを追加する方法

luaをインストールする http://luajit.org/download/LuaJIT-2.0...

MySQL で特殊文字を含むデータベース名を作成する方法の例

序文この記事では、MySQL で特殊文字を使用してデータベース名を作成する方法について説明します。こ...

Vueはプログレスバーの変更効果を実現します

この記事ではVueを使ってプログレスバーの変更を簡単に実装してみましたので参考にしてください。具体的...

MySQL マスター スレーブ データが矛盾しています。プロンプト: Slave_SQL_Running: 解決策はありません

この記事では、MySQL マスターとスレーブ データ間の不一致の解決方法と、プロンプト「Slave_...