序文 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 関数呼び出し、適用、バインド メソッドのケース スタディ
この記事は、WindowsでのMySQL 8.0.11のインストールチュートリアルを記録しています。...
この記事では主に、v-if と v-for を一緒に使用することが推奨されない理由を紹介します。詳細...
まず、top のいくつかのフィールドの意味を紹介します。 VIRT:仮想メモリ使用量1. プロセスが...
失敗の原因今日、カルーセルを書いていたときに、overflow;hidden; が失敗する可能性があ...
目次jQuery の $.ajax Webpack時代の始まり約束について深く考えるネストをなくすj...
ネイティブJSによって開始されたネットワークリクエストは、クエリ文字列の形でサーバーに送信されるため...
注: データベースのバージョンの問題により、プロジェクトの起動時にエラーは発生しませんでしたが、デー...
さっそく、コードを直接投稿します。具体的なコードは次のとおりです。 <!DOCTYPE htm...
2019年から、AndroidとiOSの両方のプラットフォームでダークモードが使用され始めました。も...
ご存知のとおり、CSS の絶対位置はデフォルトでドキュメントに応じて設定されます。たとえば、posi...
1. Vueルーティングの権限制御には一般的に2つの方法がありますa. ルーティングメタ情報(メタ)...
今日は、さまざまなブラウザでのデフォルト要素のマージン値が何であるかという問題について説明しました。...
noscript の定義と使用法noscript 要素は、スクリプトが実行されない場合の代替コンテン...
目次テーブルの競合を見つけて修正するインデックス統計の更新テーブルの競合を見つけて修正するデータ テ...
MySQL 5.7 より前のバージョンのパスワードを変更する方法:方法1: SET PASSWORD...