Nginx がリクエストを処理する際のマッチングルールの詳細な分析

Nginx がリクエストを処理する際のマッチングルールの詳細な分析

nginx はリクエストを受信すると、まず server_name でサーバーを照合し、次にサーバー内の場所を使用して照合を続行します。

server_name に一致

nginx では、server_name によって、リクエストを受信したときにどのサーバーが使用されるかが決まります。nginx は、リクエスト ヘッダーの Host フィールドを使用して server_name と照合します。server_name を定義するときは、フル ネーム、ワイルドカード名、または正規表現名を使用できます。照合順序は次のとおりです。

  • 完全一致
  • 文字列の前のワイルドカード文字、つまり *.example.org
  • ワイルドカードマッチング後、例: mail.*
  • 正規表現マッチング

一致するものが見つからない場合は、default_server が処理に使用されます。定義されていない場合は、最初に定義されたものが使用されます。例として 3 つの単純なサーバーを使用し、ポート 80 を listen し、server_name をそれぞれ *.org、*.net、*.com に設定します。

サーバー{
 聞く 80;
 サーバー名 example.org www.example.org;
 401 を返します。
}

サーバー{
 聞く 80;
 サーバー名 example.net www.example.net;
 402 を返します。
}

サーバー{
 聞く 80;
 サーバー名 example.com www.example.com;
 403 を返します。
}

上記の設定では、デフォルト サーバーは最初のサーバーです。存在しないサーバーにアクセスすると、401 が返されます。ただし、default_server を使用して手動でデフォルト ホストを設定できます。default_server は、次のように listen フィールドで設定されます。

サーバー{
 80 default_server をリッスンします。
 サーバー名 example.net www.example.net;
}

再度マッチングを行った際に、一致するものが見つからない場合は、このサーバーが使用されます。

アクセスが拒否されました

ホスト フィールドのないリクエストを禁止する場合は、次のサーバーを定義できます。

サーバー{
 聞く 80;
 サーバー名 "";
 444を返します。
}

server_name は空の文字列として定義されます。Host フィールドが空であるか存在しない場合は、このサーバーが一致し、404 ステータス コードが返されます。

Nginx の 444 ステータスは特殊です。444 が返された場合、Web サイトに接続できないのと同様に、クライアントはサーバーから返された情報を受け取らず、ブラウザには直接 502 が表示されます。ただし、リバース プロキシを使用している場合は、通常のステータス コードが表示されます。

存在しないホストへのアクセスを禁止したい場合は、次のように定義できます。

サーバー{
 80 default_server をリッスンします。
 サーバー名_;
 444を返します。
}

_ には特別な意味はありません。ドメイン名は _ 内には表示されないため、実際のドメイン名と同じにはなりません。他の不正な文字についても同様です。

IPとserver_nameの両方に一致

次に、異なるリスニング IP と異なる server_name の混在を処理する方法を見てみましょう。

サーバー{
 192.168.1.1:80 を聴く;
 サーバー名 example.org www.example.org;
}

サーバー{
 192.168.1.1:80 を聴く;
 サーバー名 example.net www.example.net;
}

サーバー{
 192.168.1.2:80 を聴く;
 サーバー名 example.com www.example.com;
}

この設定では、nginx は最初に IP を照合し、次に server_name を照合します。一致する server_name がない場合、デフォルトのサーバーが使用されます。たとえば、ドメイン名 www.example.com のリクエストが 192.168.1.1:80 から送信され、192.168.1.1:80 でリッスンしているサーバーが 2 つしかなく、どちらも www.example.com に一致しない場合は、2 つのサーバーのデフォルトのホストが使用されます。リスナーの定義に default_server が使用されていないため、デフォルトは最初のサーバー www.example.org です。もちろん、default_server を定義することもできます。

サーバー{
 192.168.1.1:80 を聴く;
 サーバー名 example.org www.example.org;
}

サーバー{
 192.168.1.1:80 default_server をリッスンします。
 サーバー名 example.net www.example.net;
}

サーバー{
 192.168.1.2:80 default_server をリッスンします。
 サーバー名 example.com www.example.com;
}

一致する場所

nginx はサーバーに一致した後、場所を介してリクエストの処理を続行します。次に例を示します。

サーバー{
 172.17.0.3:80を聴く;
 サーバー名_;

 位置 / {
 401 を返します。
 }

 場所 ~*\.(gif|jpg|png)$ {
 402 を返します。
 }
 
 場所 ~*\.(gif|jpg|png)$ {
 404 を返します。
 }

 場所 /api {
 403 を返します。
 }
}

Nginx は最初にすべての場所でプレフィックスを検索して一致させます。プレフィックスを一致させた後、正規表現で定義された場所を順番に一致させます。一致した場合は終了します。一致しない場合は、前にプレフィックスと一致した場所を使用して処理します。以下は、特定の一致の例です。

  • /x.gif リクエストは、最初にプレフィックス / と一致し、次に残りの x.gif と場所の正規表現を使用して一致し、最初に場所 ~*\.(gif|jpg|png)$ と一致し、402 を返します。
  • /x.pdf リクエストは、x.pdf が一致しないため、場所 / を使用して処理されます。
  • /api/x.gif は、最初にプレフィックス /api と一致し、次に残りの x.gif と場所の正規表現を使用して一致し、最初に場所 ~*\.(gif|jpg|png)$ と一致し、402 を返します。
  • /api/x.pdf へのリクエストは、x.pdf が一致しないため、場所 /api を使用して処理されます。

参照する

  • nginxがリクエストを処理する方法
  • サーバー名

要約する

以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。

以下もご興味があるかもしれません:
  • Nginx ロケーションマッチングルールの詳細な説明
  • Nginxサーバのロケーションディレクティブマッチングルールの詳細な説明
  • Nginx ロケーションマッチングルールの例
  • nginx マッチングルールの簡単な概要 (推奨)
  • Nginx のロケーション マッチング ルールの概要
  • Nginx ロケーション ディレクティブ URI マッチング ルールの詳細な概要

<<:  MySQL マスターとスレーブの不整合とその解決策の詳細な説明

>>:  {{ }} で関数を直接使用する WeChat アプレットの例

推薦する

WeChatアプレットは記録機能を実装します

この記事では、WeChatアプレットのレコード機能を実装するための具体的なコードを参考までに紹介しま...

Linux LVM 論理ボリューム構成プロセス (作成、増加、削減、削除、アンインストール) の詳細な説明

Linux LVM論理ボリューム構成プロセスの詳細な説明多くの Linux ユーザーは、オペレーティ...

HTML ハイパーリンク内の中国語文字化けの分析と解決

Vm 内のハイパーリンク URL は、Get 要求のパラメータとして中国語と連結する必要があります。...

MySQLの読み書き分離により挿入後にデータが選択されなくなる問題を解決

MySQLは独立した書き込み分離を設定します。コードに次のものを書くと問題が発生する可能性があります...

Linux 環境変数の設定方法のまとめ (.bash_profile と .bashrc の違い)

Linux では、アプリケーションをダウンロードしてインストールすると、起動時にアプリケーション名...

jQuery はテーブルのページング効果を実装します

この記事では、テーブルのページング効果を実現するためのjQueryの具体的なコードを参考までに紹介し...

MySQL 5.7 mysql コマンドラインクライアントの使用コマンドの詳細

MySQL 5.7コマンドを使用するMySQLコマンドラインクライアント1. パスワードを入力してく...

CSS の :focus-within の楽しさについて簡単に説明します

Bステーションでパスワードを入力するときに目を覆っているこの画像を見たことがある人もいると思いますこ...

MySQLの構文、特殊記号、正規表現の詳細な説明

Mysql でよく使用される表示コマンド1. 現在のデータベース サーバー内のデータベースの一覧を表...

JavaScript でプライベート メンバーを作成する

目次1. クロージャを使用する2. ES6クラスを使用する3. ES2020提案を使用する4. We...

支払いカウントダウンを実現し、ホームページに戻るためのjs

ホーム ページに戻るための支払いカウントダウン ケースの概要: シンプルな js 構文、getEle...

jwtを使用してノードによって生成されたトークンをどこに保存するかについての簡単な説明

A: 通常はクライアントに保存されます。 jwt または JSON Web Token は、リクエス...

JavaScript 改ざん防止オブジェクトの使用例

目次JavaScript 改ざん防止オブジェクト1. 拡張不可能なオブジェクト2. 封印された物体3...

IE6 ウェブページ作成リファレンス IE6 デフォルトスタイル

これは実際には IE の公式ドキュメントではありません。他の人が実践を通じて開発した IE6 のデフ...

Reactフック入門チュートリアル

ステートフック例: 'react' から useState をインポートします。 関...