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

推薦する

MySQL 外部キー設定方法の例

1. 外部キーの設定方法1. MySQL では、2 つのテーブルを関連付けるために、外部キー (FO...

Linux コマンドライン操作 Baidu クラウドのファイルのアップロードとダウンロード

目次0. 背景1. インストール2. Baidu Cloudアカウントにログインする3. ファイルを...

MySQLでインデックスエラーが発生する状況について簡単に説明します

以下に、トレーニング機関からのヒントと私自身の要約をいくつか示します。以下のインデックスの内容を説明...

JavaScriptは入力ボックスコンポーネントを実装します

この記事では、入力ボックスコンポーネントを手動で実装するための具体的なコードを参考までに紹介します。...

Windows Server 2008 R2 リモート デスクトップのポート 3389 を変更する方法

Windows サーバー リモート デスクトップのデフォルトのポート番号は 3389 です。職場でサ...

テキストエリア テキストエリアの幅と高さ 幅と高さの自動適応実装コード

コードをコピーコードは次のとおりです。 <HTML> <ヘッド> <T...

mysql8.0.11 winx64 のインストールと設定方法のグラフィック チュートリアル (win10)

mysql 8.0.11 winx64のインストールチュートリアルは以下のように記録され、みんなと...

CSS フロントエンドページレンダリング最適化属性 will-change の具体的な使用法

序文スクロールやサイズ変更などのスクロール イベントがトリガーされると、トリガーの頻度が非常に高くな...

mysql order by in の文字順序の詳細な説明 (推奨)

//MySQL ステートメント SELECT * FROM `MyTable` WHERE `id...

Vue ElementUI は非同期読み込みツリーを実装します

この記事の例では、vue ElementUI の非同期読み込みツリーを実装するための具体的なコードを...

よく使われるCSSカプセル化方法の概要

1. pc-reset PCスタイルの初期化 /* 正規化.css */ html{ 行の高さ: 1...

MySQLクエリが遅い場合の理由と解決策

Python プログラムを書き、Mysql ライブラリを集中的に操作したためです。データ量が多くない...

Html+CSS 描画三角形アイコン

まずはレンダリングを見てみましょう: XML/HTML コードコンテンツをクリップボードにコピー&l...

Webデザインの経験: Webコードを効率的に書く

本来、この第 7 章では、デザインにおけるレイヤーと空間テクニックについて深く議論するはずです。しか...

ボタンと入力タイプの違いと注意点

<button> タグ<br />定義と使用法<button> ...