検索
ホームページ運用・保守NginxNginx http ヘルスチェックを構成する方法

パッシブ チェック

パッシブ ヘルス チェックの場合、nginx および nginx plus はイベントの発生を監視し、失敗した接続の回復を試みます。それでも機能しない場合、nginx オープン ソースと nginx plus はサーバーを利用不可としてマークし、再びアクティブとしてマークされるまで、サーバーへのリクエストの送信を一時的に停止します。

上流サーバーが使用不可としてマークされる条件は、ブロック内のサーバー ディレクティブのパラメータ上流で上流サーバーごとに定義されます:

  • fail_timeout - セットサーバー マーク 利用できない場合に複数の試行が失敗するまでの時間、およびサーバーが利用不可能としてマークされる時間 (デフォルトは 10 秒)。

  • max_fails - 失敗した試行の回数を設定します。この回数を超えると、fail_timeout サーバーは使用不可としてマークされます (デフォルトは 1 回の試行です)。次の例では、nginx がサーバーへのリクエストの送信に失敗するか、30 秒以内に 3 回応答を受信しない場合、サーバーが 30 秒以内に利用できなくなることを意味します:

upstream backend {
  server backend1.example.com;
  server backend2.example.com max_fails=3 fail_timeout=30s;
}

注意すべき点 はい、サーバー グループが 1 つだけの場合、fail_timeout パラメーターと max_fails パラメーターは無視され、サーバーが使用不可としてマークされることはありません。

サーバーの起動が遅い

最近復元されたサーバーは簡単に接続が殺到する可能性があり、サーバーが再び使用不可としてマークされる可能性があります。スロー スタートを使用すると、アップストリーム サーバーが回復するか使用可能になった後、その重みをゼロから公称値まで徐々に復元できます。これは、アップストリームのサーバー モジュールの throw_start パラメータを指定することで実行できます。

upstream backend {
  server backend1.example.com slow_start=30s;
  server backend2.example.com;
  server 192.0.0.1 backup;
}

注: グループ内にサーバーが 1 つしかない場合、slow_start パラメータは無視され、サーバーが使用不可としてマークされることはありません。スロー スタートは nginx plus の独自機能です

nginx plus のアクティブ チェック

nginx plus は、特別なヘルス チェック リクエストを各サーバーに送信することでこれを実行できます。正しい応答を確認することで、上流サーバーの健全性を定期的にチェックします。

アクティブなヘルスチェックを有効にするには:

1. リクエスト (proxy_pass) を location ブロックの上流グループに渡すプロセスに、health_check ディレクティブを含めます:

server {
 location / {
   proxy_pass http://backend;
   health_check;
 }
}

このコード スニペットは、場所に対するすべてのリクエストを照合するサーバーを定義し、バックエンドと呼ばれるアップストリーム グループに渡します。また、health_check ディレクティブを使用した高度なヘルス監視も有効になります。デフォルトでは、nginx plus はグループ バックエンド内の各サーバーに「/」リクエストを 5 秒ごとに送信します。

通信エラーまたはタイムアウトが発生した場合 (サーバーから返されたステータス コードが 200 ~ 399 の範囲外である場合)、ヘルス チェックは失敗します。サーバーは異常としてマークされ、nginx plus はヘルスチェックに再度合格するまでクライアントリクエストをサーバーに送信しません。

もう 1 つのオプション オプション: ヘルス チェック用に別のポートを指定することもできます。たとえば、同じホスト上の多くのサービスの健全性を監視することができます。ディレクティブの port パラメーターを使用して、新しいポート health_check を指定します:

server {
 location / {
   proxy_pass  http://backend;
   health_check port=8080;
 }
}

2。アップストリーム サーバー グループで、zone ディレクティブを使用して共有メモリ領域を定義します:

http {
 upstream backend {
   zone backend 64k;
   server backend1.example.com;
   server backend2.example.com;
   server backend3.example.com;
   server backend4.example.com;
 }
}

この領域は、上流グループ間で共有されるすべてのワーカー プロセス間にあり、上流グループの構成が格納されます。これにより、ワーカー プロセスは同じカウンター セットを使用して、グループ内のサーバーからの応答を追跡できるようになります。

アクティブなヘルスチェックのデフォルト値は、health_check ディレクティブの引数を使用してオーバーライドできます:

location / {
  proxy_pass http://backend;
  health_check interval=10 fails=3 passes=2;
}

ここでは、interval パラメーターにより、ヘルスチェック間の遅延がデフォルトの 5 秒から 10 秒に増加します。 。 failed パラメーターでは、サーバーを異常としてマークするには、サーバーが 3 つのヘルスチェックに失敗する必要があります (デフォルト値から開始)。最後に、pass パラメーターは、サーバーがデフォルト値ではなく再び正常とマークされる前に、サーバーが 2 つの連続したチェックに合格する必要があることを意味します。

リクエストされた URL を指定します

health_check ディレクティブで uri パラメータを指定して、ヘルス チェック リクエストのルートを設定します:

location / {
  proxy_pass http://backend;
  health_check uri=/some/path;
}

指定された URI は、上流ブロックでサーバーに設定されたサーバー ドメイン名または IP アドレスに追加されます。上記で宣言されたバックエンド サンプル グループの最初のサーバーの場合、ヘルス チェックは URI http://backend1.example.com/some/path を要求します。

カスタム条件の定義

サーバーがヘルス チェックに合格するために応答が満たす必要があるカスタム条件を設定できます。条件は match ブロックで定義され、health_check ディレクティブの引数で参照されます。

1. http {} レベルで、match {} ブロックを指定し、名前を付けます。たとえば、ブロックの match パラメーターを指定して、「server_ok'

http {
 #... 
 match server_ok {
   # tests are here     
 }
}

2.health_check」と名前を付けます。パラメータ ブロックの名前:

http {
 #... 
 match server_ok {
   status 200-399;
   body !~ "maintenance mode";
 }
 server {
   #...     
   location / {
     proxy_pass http://backend;
     health_check match=server_ok;
   }
 }
}

と一致する 応答のステータス コードが 200 ~ 399 の範囲にあり、その本文に文字列 'maintenance mode'

が含まれていない場合、ヘルス チェックに合格します。

match ディレクティブにより、nginx plus がステータス コード、ヘッダー フィールド、応答本文をチェックできるようになります。このディレクティブを使用して、ステータスが指定された範囲内にあること、応答にヘッダーが含まれていること、またはヘッダーまたは本文が正規表現と一致することを検証します。 match ディレクティブには、ステータス条件、本文条件、および複数のタイトル条件を含めることができます。サーバーがヘルスチェックに合格するには、応答が match ブロックで定義されたすべての条件を満たしている必要があります。

例如,下面的 match 指令匹配有状态代码响应 200,精确值 text/html 的content-type 标题,页面中的文字:'welcome to nginx!'.

match welcome {
  status 200;
  header content-type = text/html;
  body ~ "welcome to nginx!";
}

以下示例使用感叹号(!)来定义响应不得通过运行状况检查的特征。在这种情况下,健康检查在非 301,302,303,或 307状态码,同时并没有 refresh 头信息时将通过检查,。

match not_redirect {
  status ! 301-303 307;
  header ! refresh;
}

健康检查可以在其他非 http 协议中启用, 例如 fastcgi, , scgi,  甚至 tcp 和 udp。

很多很好的特性,就是需要 nginx plus 才能使用。

以上がNginx http ヘルスチェックを構成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事は亿速云で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
Nginx in Action:例と現実世界のアプリケーションNginx in Action:例と現実世界のアプリケーションApr 17, 2025 am 12:18 AM

Nginxは、Webサイトのパフォーマンス、セキュリティ、およびスケーラビリティを改善するために使用できます。 1)逆プロキシおよびロードバランサーとして、Nginxはバックエンドサービスを最適化し、トラフィックを共有できます。 2)イベント駆動型および非同期アーキテクチャを通じて、nginxは高い並行接続を効率的に処理します。 3)構成ファイルでは、静的ファイルサービスやロードバランシングなどのルールの柔軟な定義を可能にします。 4)最適化の提案には、GZIP圧縮の有効化、キャッシュの使用、およびワーカープロセスの調整が含まれます。

Nginxユニット:さまざまなプログラミング言語をサポートしますNginxユニット:さまざまなプログラミング言語をサポートしますApr 16, 2025 am 12:15 AM

Nginxunitは複数のプログラミング言語をサポートし、モジュラー設計を通じて実装されています。 1。言語モジュールの読み込み:構成ファイルに従って対応するモジュールをロードします。 2。アプリケーションの起動:呼び出し言語が実行されたときにアプリケーションコードを実行します。 3。リクエスト処理:リクエストをアプリケーションインスタンスに転送します。 4。応答返品:処理された応答をクライアントに返します。

nginxとapacheを選択する:あなたのニーズに合った適切nginxとapacheを選択する:あなたのニーズに合った適切Apr 15, 2025 am 12:04 AM

NginxとApacheには独自の利点と短所があり、さまざまなシナリオに適しています。 1.Nginxは、高い並行性と低リソース消費シナリオに適しています。 2。Apacheは、複雑な構成とリッチモジュールが必要なシナリオに適しています。コア機能、パフォーマンスの違い、ベストプラクティスを比較することで、ニーズに最適なサーバーソフトウェアを選択するのに役立ちます。

nginxを開始する方法nginxを開始する方法Apr 14, 2025 pm 01:06 PM

質問:nginxを開始する方法は?回答:nginxスタートアップnginx検証nginxはnginxを開始しました他のスタートアップオプションを自動的に開始

Nginxが開始されるかどうかを確認する方法Nginxが開始されるかどうかを確認する方法Apr 14, 2025 pm 01:03 PM

nginxが開始されるかどうかを確認する方法:1。コマンドラインを使用します:SystemCTLステータスnginx(Linux/unix)、netstat -ano | FindStr 80(Windows); 2。ポート80が開いているかどうかを確認します。 3.システムログのnginx起動メッセージを確認します。 4. Nagios、Zabbix、Icingaなどのサードパーティツールを使用します。

nginxを閉じる方法nginxを閉じる方法Apr 14, 2025 pm 01:00 PM

NGINXサービスをシャットダウンするには、次の手順に従ってください。インストールタイプを決定します:Red Hat/Centos(SystemCtl Status Nginx)またはDebian/Ubuntu(Service Nginx Status)サービスを停止します:Red Hat/Centos(SystemCtl Stop Nginx)またはDebian/Ubuntu(Service Nginx Stop)無効自動起動(オプション):Debuntos/Centos/Centos/Centos/Centos/Centos (syst

Windowsでnginxを構成する方法Windowsでnginxを構成する方法Apr 14, 2025 pm 12:57 PM

Windowsでnginxを構成する方法は? nginxをインストールし、仮想ホスト構成を作成します。メイン構成ファイルを変更し、仮想ホスト構成を含めます。 nginxを起動またはリロードします。構成をテストし、Webサイトを表示します。 SSLを選択的に有効にし、SSL証明書を構成します。ファイアウォールを選択的に設定して、ポート80および443のトラフィックを許可します。

nginx403エラーを解く方法nginx403エラーを解く方法Apr 14, 2025 pm 12:54 PM

サーバーには、要求されたリソースにアクセスする許可がなく、NGINX 403エラーが発生します。ソリューションには以下が含まれます。ファイル許可を確認します。 .htaccess構成を確認してください。 nginx構成を確認してください。 SELINUXアクセス許可を構成します。ファイアウォールルールを確認してください。ブラウザの問題、サーバーの障害、その他の可能なエラーなど、他の原因をトラブルシューティングします。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません