我有一个基于php的SAAS产品以及apache2和mysql,它已经托管在AWS上。我的生产在高峰时间非常缓慢,当我检查服务器状态时,它说空闲工作人员为0(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根据细节,我可以看到1GB的内存仍然是免费的。那么没有闲散的工人吗?此外,当我将MaxRequestWorkers设置为450时,为什么只有256个请求没有空闲工作人员。机器的最大内存是8GB。
发布于 2020-08-25 11:35:06
使用MPM预叉时,如果您增加了MaxRequestWorkers,您还需要提高ServerLimit。
对于非线程服务器(即预叉),MaxRequestWorkers转换为将启动以服务请求的子进程的最大数量。默认值为256;要增加它,还必须提高ServerLimit。
https://httpd.apache.org/docs/2.4/mod/mpm_common.html#maxrequestworkers
发布于 2020-08-25 11:40:13
使用mpm_prefork,new服务器产生新的进程来处理请求。每个进程一次只能处理一个请求。
在您的示例中,您的set服务器被设置为至少有5个空闲服务器进程等待处理请求,最多有10个。考虑到您同时处理250多个请求,可能是您的set服务器无法足够快地生成新进程。
我会增加StartServers、MinSpareServers和MaxSpareServers值,以确保您有足够的可用容量来加载尖峰或重载。
您还可以考虑根据需要服务的工作负载类型,更改为另一个多处理模块。
编辑:@tetech的答案是正确的,但是您也可以考虑调整这些值,因为这样可以提高one服务器的性能。
https://serverfault.com/questions/1031399
复制相似问题