位置一致順序 1. 「=」プレフィックス命令マッチング、マッチングが成功したら他のマッチングを停止 注記 1. 一致順序は、最初に通常の文字列と一致し、次に正規表現と一致します。また、共通文字列のマッチング順序は、設定内の文字の長さに応じて長いものから短いものの順になります。つまり、共通文字列で設定された場所の順序は関係ありません。最終的には、nginx は設定の長さに応じてマッチングを行います。ただし、正規表現は設定ファイル内の順序でテストされることに注意してください。正規表現の最初の一致が見つかると検索は停止します。 2. 一般的に、通常の文字列の位置の一致が成功すると、正規表現の位置も一致します。この動作を変更するには 2 つの方法があります。1 つは「=」プレフィックスを使用することです。これは厳密な一致を実行し、リクエストの処理中に一致が成功した後すぐに他の一致を停止します。もう 1 つは「^~」プレフィックスを使用することです。このプレフィックスを通常の文字列に使用すると、パスが一致する場合に nginx に正規表現をテストしないように指示します。 パターンと順序の一致 先頭の Location = /uri = は完全一致を示し、完全一致のみが有効になります。 location ^~ /uri ^~ は URL パスのプレフィックス一致で始まり、正規表現の前に来ます。 先頭の位置 ~ パターン ~ は、大文字と小文字を区別する正規一致を示します。 場所 ~* パターン ~* は大文字と小文字を区別しない正規表現で始まります。 修飾子のない location /uri もプレフィックス一致を示しますが、正規表現一致の後になります。 location / Universal matching では、他の場所と一致しないリクエストが一致します。これは、switch の default に相当します。 実験例 「^~」と「~」をテストします。nginx の設定は次のとおりです。ブラウザに http://localhost/helloworld/test と入力すると、601 が返されます。 #1 をコメントアウトして #2 を開き、ブラウザに http://localhost/helloworld/test と入力すると、603 が返されます。注意: #1 と #2 は同時に開くことはできません。これら 2 つは通常の文字列であるため、同時に開くと、nginx の起動時に nginx: [emerg] duplicate location "/helloworld"... が報告されます。 場所 ^~ /helloworld { #1 601を返します。 } #場所 /helloworld { #2 # 602 を返します。 #} 場所 ~ /helloworld { 603を返します。 } 共通文字列の長さをテストします (共通文字列の一致は順序とは関係なく長さに関係します)。ブラウザに http://localhost/helloworld/test/a.html と入力すると、601 が返されます。ブラウザに http://localhost/helloworld/a.html と入力すると、602 が返されます。 場所 /helloworld/test/ { #1 601を返します。 } 場所 /helloworld/ { #2 602を返します。 } 正規表現の順序をテストします (正規表現の一致は順序に依存します)。ブラウザに http://localhost/helloworld/test/a.html と入力して 602 を返します。#2 と #3 の順序を入れ替えて、ブラウザに http://localhost/helloworld/test/a.html と入力して 603 を返します。 場所 /helloworld/test/ { #1 601を返します。 } 場所 ~ /helloworld { #2 602を返します。 } 場所 ~ /helloworld/test { #3 603を返します。 } したがって、実際の使用では、次のように少なくとも 3 つの一致ルール定義があると思います。 #ウェブサイトのルートと直接一致します。ドメイン名を介してウェブサイトのホームページにアクセスする方が頻繁になります。これを使用すると、処理が高速化されると公式サイトは述べています。 #これはバックエンドアプリケーションサーバーに直接転送されるか、静的ホームページになる場合があります# 最初に必要なルールの場所 = / { proxy_pass http://tomcat:8080/index } # 2 番目の必須ルールは、静的ファイル要求を処理することです。これは、http サーバーとしての nginx の強みです。# ディレクトリ マッチングまたはサフィックス マッチングの 2 つの構成モードがあり、どちらかを選択するか、両方を使用します。location ^~ /static/ { ルート /webroot/static/; } 場所 ~* \.(gif|jpg|jpeg|png|css|js|ico)$ { ルート /webroot/res/; } #3 番目のルールは一般的なルールで、動的なリクエストをバックエンド アプリケーション サーバーに転送するために使用されます。#非静的ファイル リクエストはデフォルトで動的なリクエストであり、実際の状況に応じて把握できます。#結局のところ、人気のあるフレームワークの中には、.php や .jsp のサフィックスが付いているものはほとんどありません。location / { プロキシパス http://tomcat:8080/ } 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: CentOS で MySQL 5.1 を 5.5.36 にアップグレードする
>>: React+Antdはテーブルの追加、削除、変更の例を実装します
docker イメージを使用する場合、以下に示すように、REPOSITORY と TAG の両方が ...
1 はじめにKong は単純な製品ではありません。この記事で言及されている Kong は主に Kon...
まず、データベース テーブルを作成します。 テーブル `t_demo` を作成します ( `id` ...
まず、マージン崩壊が発生する 3 つの状況を見てみましょう。 1. 隣接する 2 つのブロックレベル...
DOMContentLoaded イベント文字通り、DOM がロードされた後に実行されます。 win...
長い間何もしていなかった人は、努力をすると一生懸命働いていると思うようになります。 1. 問題Nav...
<br />当サイトのオリジナルコンテンツですので、転載の際は出典を123WORDPRE...
最近、Yahoo の 34 の黄金律を読み、ウェブサイトのパフォーマンスを最適化する方法を学びました...
Sttty は、Linux で端末設定を変更および印刷するための一般的なコマンドです。 1. パラ...
VMware仮想マシンでのCentos7ブリッジネットワーク構成の完全な手順は参考用です。具体的な内...
序文:グループ化関数はグループ内の最初のデータを取得しますが、各グループ内の最新のデータを取得する必...
1. 原因要件は 2 行を表示することであり、余分なテキストは 3 つのドットに置き換えられるため、...
目次導入ステップ1ステップ2: アイデアで動的Webプロジェクトを作成するステップ3: Tomcat...
1. 仮想マシンバージョン15.5.1をダウンロードする公式サイトから直接最新バージョンをダウンロー...
具体的なコードは次のとおりです。 <a href="#"> <...