Apache2 服务器中零空闲工作者导致性能问题

Apache2 服务器中零空闲工作者导致性能问题

我有一个基于 php 以及 apache2 和 mysql 构建的 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 是 8GB

答案1

使用 MPM prefork,如果增加,MaxRequestWorkers则还需要提高ServerLimit

对于非线程服务器(即 prefork),MaxRequestWorkers 表示将启动用于处理请求的最大子进程数。默认值为 256;要增加该值,还必须增加 ServerLimit。

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

答案2

使用 mpm_prefork,Web 服务器会生成新进程来处理请求。每个进程每次只能处理一个请求。

在您的示例中,您的 Web 服务器设置为至少有 5 个空闲服务器进程等待处理请求,最多有 10 个。考虑到您要处理超过 250 个同时发生的请求,您的 Web 服务器可能无法足够快地生成新进程。

我会增加 StartServers、MinSpareServers 和 MaxSpareServers 的值,以确保您有足够的可用容量来应对负载峰值或重负载。

根据您需要处理的工作负载类型,您可能还需要考虑更改为另一个多处理模块。

编辑:@tetech 的答案是正确的,但是您可能还希望考虑调整这些值,因为这可以提高网络服务器的性能。

相关内容