将 pm 从 切换dynamic
到后ondemand
,我的 1GB VPS 上的内存使用问题较少,但似乎在某些高负载情况下服务器仍然卡住。它是具有 1GB 真实 RAM 和 4GB“假 RAM”(SSD 缓存)的 VMWare VPS。
安装了newrelic服务器监控,发现问题好像还是php5-fpm的问题。服务器负载达到 150(2 cpu 系统),所有 php-fpm 池最多生成 10 个孩子,这消耗了将近 2.5 GB RAM,而系统上的平均 RAM 使用量为 300 MB。
如果我理解ondemand
正确,所有备用服务器设置都没有用,并且生成的孩子应该在请求完成后死亡。所以我唯一能做的就是max_children
进一步降低,但因为我有 30 多个游泳池,我想这对我来说无论如何都没有帮助。
这是我的标准池配置:
[web2]
listen = 127.0.0.1:9011
listen.allowed_clients = 127.0.0.1
user = web2
group = client1
pm = ondemand
pm.max_children = 10
pm.process_idle_timeout = 10s;
pm.max_requests = 0
有没有人知道如何优化此设置以使服务器不会在高负载情况下挂起?
******编辑****** 我试过 process.max = 32
了,但我不确定在使用ondemand
. 今天服务器又崩溃了,我不知道是什么问题。完全中等流量。如果我急于在页面上使用 blitz.io,一切都会很顺利。他产生了所有 10 个孩子,并尽可能快地传送页面,同时立即传送 500 个请求,而不会导致服务器爆炸。
终于找到问题了。
在阅读了很多关于 Wordpress 僵尸网络的内容之后,我不知道为什么我没有在第一时间想到它。所有的池都是 Wordpress 站点,它们同时被僵尸网络随机攻击,这让服务器崩溃了。
我现在安装了
fail2ban
(我很确定我也在旧服务器上完成了这个......)并且也降低max_children
了,看起来服务器现在可以在攻击中幸存下来而无需重新启动。