php5-fpm pm ondemand 和仍然存在内存问题

php5-fpm pm ondemand 和仍然存在内存问题

在将 pm 从 切换到 之后,dynamicondemand的 1GB VPS 内存使用问题减少了,但在某些高负载情况下,服务器似乎仍然会卡住。这是一款 VMWare VPS,具有 1GB 真实 RAM 和 4GB“假 RAM”(SSD 缓存)。

我安装了 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 个,而不会使服务器崩溃。

答案1

终于找到问题了。

在阅读了这么多有关 Wordpress 僵尸网络的文章后,我不知道为什么我没有一开始就想到这一点。所有池都是 Wordpress 网站,它们同时随机受到僵尸网络的攻击,这让服务器崩溃了。

我现在安装了fail2ban(我很确定我也在旧服务器上完成了这个......)并且降低了max_children,看来服务器现在可以承受攻击而无需重新启动。

相关内容