Apache2 サーバーでアイドル ワーカーがゼロになり、パフォーマンスの問題が発生する

Apache2 サーバーでアイドル ワーカーがゼロになり、パフォーマンスの問題が発生する

私は、Apache2とMySQLとともにPHPで構築されたSAAS製品を持っており、AWSでホストされています。私の生産はピーク時に非常に遅く、サーバーステータスを確認すると、アイドルワーカーが0(ゼロ)であると表示されます。私はmpm-preforkを使用しています。

Current Time: Monday, 24-Aug-2020 19:36:32 UTC
Restart Time: Friday, 14-Aug-2020 06:03:27 UTC
Parent Server Config. Generation: 12
Parent Server MPM Generation: 11
Server uptime: 10 days 13 hours 33 minutes 5 seconds
Server load: 1.17 1.07 0.95
Total accesses: 28851443 - Total Traffic: 824.8 GB
CPU Usage: u289.99 s50.68 cu0 cs0 - .0373% CPU load
31.6 requests/sec - 0.9 MB/second - 30.0 kB/request
256 requests currently being processed, 0 idle workers

以下は私のmpm-prefork.conf設定ファイルです

<IfModule mpm_prefork_module>
        StartServers                     5
        MinSpareServers           5
        MaxSpareServers          10
        MaxRequestWorkers         450
        MaxConnectionsPerChild   0
</IfModule>

ubuntu20.04 の TOP コマンドを実行すると、次の結果が出力されます。

top - 20:03:58 up 143 days, 11:16,  1 user,  load average: 0.48, 0.71, 0.83
Tasks: 369 total,   3 running, 317 sleeping,   0 stopped,   0 zombie
%Cpu(s): 15.9 us,  3.2 sy,  0.0 ni, 79.9 id,  0.0 wa,  0.0 hi,  1.0 si,  0.0 st
KiB Mem :  7865072 total,  1023492 free,  2752320 used,  4089260 buff/cache
KiB Swap:        0 total,        0 free,        0 used.  4755856 avail Mem

詳細によると、1 GB の RAM がまだ空いていることがわかります。では、アイドル ワーカーはゼロなのでしょうか? また、MaxRequestWorkers を 450 に設定しているのに、なぜ 256 のリクエストでアイドル ワーカーがゼロになるのでしょうか。マシンの最大 RAM は 8 GB です。

答え1

MPM プリフォークでは、 を増やす場合はMaxRequestWorkersも増やす必要がありますServerLimit

非スレッド サーバー (つまり、prefork) の場合、MaxRequestWorkers は、リクエストを処理するために起動される子プロセスの最大数に変換されます。デフォルト値は 256 です。この値を増やすには、ServerLimit も増やす必要があります。

https://httpd.apache.org/docs/2.4/mod/mpm_common.html#maxrequestworkers

答え2

mpm_prefork を使用すると、Web サーバーはリクエストを処理するために新しいプロセスを生成します。各プロセスは一度に 1 つのリクエストしか処理できません。

この例では、Web サーバーは、リクエストの処理を待機しているアイドル サーバー プロセスが最低 5 つ、最大 10 つになるように設定されています。250 を超えるリクエストを同時に処理していることを考えると、Web サーバーが新しいプロセスを十分な速さで生成できない可能性があります。

負荷の急増や高負荷に対して十分な容量を確保するために、StartServers、MinSpareServers、MaxSpareServers の値を増やします。

処理する必要があるワークロードの種類に応じて、別のマルチプロセッシング モジュールに変更することも検討してください。

編集: @tetech の回答は正しいものですが、Web サーバーのパフォーマンスが向上する可能性があるため、これらの値を微調整することも検討してください。

関連情報