序文 nginx モジュールには、公式とサードパーティの 2 種類があります。nginx のインストール情報を表示するには、コマンド nginx -V を使用し、--with nginx 起動時の読み込みに関する次のモジュール情報を確認できます。 realipモジュール 目的:ローカル Nginx がリバース プロキシ バックエンドにある場合、ユーザーの実際の IP アドレスを取得できます。 使用方法: realip 関数では、Nginx が ngx_http_realip_module モジュールを追加する必要がありますが、これはデフォルトではコンパイルされません。追加する必要がある場合は、コンパイル時に --with-http_realip_module オプションを追加して有効にしてください。 リアリップスコープ set_real_ip_from、real_ip_header、real_ip_recursive はすべて、http、サーバー、およびロケーション ゾーン構成で使用できます。 いくつかの realip パラメータの説明
http ヘッダーの X-Forwarded-For、X-Real-IP、およびリモート アドレスの説明 X-Forwarded-For は HTTP リクエスト ヘッダーにあり、HTTP リクエストの終了時の実際の IP アドレスを示すために使用される HTTP の拡張ヘッダーです。 形式は次のとおりです。 X-Forwarded-For: クライアント、プロキシ1、プロキシ2 Nginx プロキシは通常、次のように構成されます。 proxy_set_header ホスト $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 説明する:
Realip関数の例 以下に簡単なアーキテクチャ図を示します。 仮定1: 1. Nginx が realip モジュールを使用しない場合、2 番目の Nginx の X-Forwarded-For リクエストは 1.1.1.1 ですが、remote_addr アドレスは 2.2.2.2 です。このとき、アプリケーション サービスは X-Forwarded-For フィールドを通じてユーザーの実際の IP を取得できます。ただし、ここにはリスクがあります。中間に複数の層のリバース プロキシ サービスがある場合、一意のユーザーの実際の IP を取得することは不可能になります。 2. Nginx が realip モジュールを使用し、次のように設定されている場合、Nginx は X-Forwarded-For の最後の IP (2.2.2.2) を実際の IP として取得します。最後に、アプリケーション サービスによって取得されるアドレスも 2.2.2.2 ですが、実はこれはユーザーの IP ではありません。 2.2.2.2 から実際の IP を設定します。 2.2.2.3 から set_real_ip_from; real_ip_header X-Forwarded-For; real_ip_recursive をオフ; 3. Nginx が realip モジュールを使用し、次のように設定されている場合、2.2.2.2 は信頼できるサーバー IP であるため、Nginx は前方検索を続行し、1.1.1.1 が信頼できるサーバー IP ではないことを検出すると、それを実際の IP と見なします。しかし、実際には 1.1.1.1 はユーザーの IP です。最後に、アプリケーション サービスはユーザーの固有の実際の IP も取得します。 2.2.2.2 から実際の IP を設定します。 2.2.2.3 から set_real_ip_from; real_ip_header X-Forwarded-For; real_ip_recursive オン; 要約する Nginx 基礎学習における realip モジュールの使用に関するこの記事はこれで終わりです。Nginx realip モジュールの使用に関する詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: mysql-8.0.19-winx64 をインストールしてログインするための初心者向けチュートリアル (初心者必読)
>>: JavaScript 関数呼び出し、適用、バインド メソッドのケース スタディ
Nginx 仮想ドメイン名設定を使用すると、ドメイン名を購入せずに特定のドメイン名を介してローカル ...
netem と tc: netem は、Linux カーネル バージョン 2.6 以降で提供されるネ...
序文皆さんは Linux で top コマンドを使ったことがあると思います。私は Linux に触れ...
ウェブサイト体験の分類1. 感覚体験:快適性を重視した視聴覚体験をユーザーに提供します。 2. イン...
MySQL には次のログがあります。エラーログ: -log-errクエリログ: -logスロークエリ...
Taobao用の空白スペースを作成します。 ブラウザページを縮小すると、コンテンツ領域は縮小されませ...
p>「サービス」で手動で起動すると、 コンソールから起動します: 次に、...\MySQL S...
置換を削除したり文字列を削除したりできる tr コマンドは、誰もがよく知っています。 英語では、英語...
1. MySQLが以前にインストールされていたかどうかを確認するコマンド: rpm -qa|grep...
目次1. mixin の使い方は? 2. ミックスイン使用時の注意2.1. ミックスイン オブジェク...
Navicat クライアントを通じてデフォルトの日時値を変更する際に問題が発生しました。データベース...
1. 仮想化 vcenter に入り、ブラウザでログインし (クライアントは設定する場所を見つけませ...
ここでは、PHP、JSP、または .NET 環境については説明しません。アーキテクチャの観点から問題...
CI/CD の概要CIワークフロー設計Gitコードバージョン管理システムはコマンドラインでのみ管理で...
最近、小さなプログラム プロジェクトを引き継いだのですが、リストを日付と時刻で並べ替えるという要件が...