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

Nginx http ヘルスチェックを構成する方法

May 14, 2023 pm 06:10 PM
http nginx

パッシブ チェック

パッシブ ヘルス チェックの場合、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 までご連絡ください。

ホット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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Linuxでnginxを開始する方法 Linuxでnginxを開始する方法 Apr 14, 2025 pm 12:51 PM

Linuxでnginxを開始する手順:nginxがインストールされているかどうかを確認します。 systemctlを使用して、nginxを開始してnginxサービスを開始します。 SystemCTLを使用して、NGINXがシステムスタートアップでNGINXの自動起動を有効にすることができます。 SystemCTLステータスNGINXを使用して、スタートアップが成功していることを確認します。 Webブラウザのhttp:// localhostにアクセスして、デフォルトのウェルカムページを表示します。

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 12:27 PM

NGINXサーバーを起動するには、異なるオペレーティングシステムに従って異なる手順が必要です。Linux/UNIXシステム:NGINXパッケージをインストールします(たとえば、APT-GetまたはYumを使用)。 SystemCtlを使用して、NGINXサービスを開始します(たとえば、Sudo SystemCtl Start NGinx)。 Windowsシステム:Windowsバイナリファイルをダウンロードしてインストールします。 nginx.exe実行可能ファイルを使用してnginxを開始します(たとえば、nginx.exe -c conf \ nginx.conf)。どのオペレーティングシステムを使用しても、サーバーIPにアクセスできます

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

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

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 am 10:33 AM

Nginx 403禁止エラーを修正する方法は?ファイルまたはディレクトリの許可を確認します。 2。HTACCESSファイルを確認します。 3. nginx構成ファイルを確認します。 4。nginxを再起動します。他の考えられる原因には、ファイアウォールルール、Selinux設定、またはアプリケーションの問題が含まれます。

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

質問への回答:304変更されていないエラーは、ブラウザがクライアントリクエストの最新リソースバージョンをキャッシュしたことを示しています。解決策:1。ブラウザのキャッシュをクリアします。 2.ブラウザキャッシュを無効にします。 3.クライアントキャッシュを許可するようにnginxを構成します。 4.ファイル許可を確認します。 5.ファイルハッシュを確認します。 6. CDNまたは逆プロキシキャッシュを無効にします。 7。nginxを再起動します。

Nginxが起動されているかどうかを確認する方法は? Nginxが起動されているかどうかを確認する方法は? Apr 14, 2025 pm 12:48 PM

Linuxでは、次のコマンドを使用して、nginxが起動されるかどうかを確認します。SystemCTLステータスNGINXコマンド出力に基づいて、「アクティブ:アクティブ(実行)」が表示された場合、NGINXが開始されます。 「アクティブ:非アクティブ(dead)」が表示されると、nginxが停止します。

See all articles