使用php-fpm和nginx进行奇怪的性能波动

前端之家收集整理的这篇文章主要介绍了使用php-fpm和nginx进行奇怪的性能波动前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在对Web服务进行负载测试.这是一个运行在PHP-fpm和Nginx上的PHP应用程序,带有fastcgi.有一个 @L_301_0@后端仅用于小型读取.

总是,我看到一种奇特的模式:性能稳定并且随着流量的增加而可预测地增加,但随后它在峰值时变得不稳定:cpu使用率不断波动.

这是我看到的性能模式(用nmon可视化):

下降总是与我的负载测试工具 – locust.io – 在完成升级到我为测试设置的峰值水平时所具有的短暂暂停一致.

我的假设:在这个短暂的时刻,PHP-fpm主人认为负载已经消失并开始杀死工人;当流量在一段时间后全面恢复时,它无法快速响应.

我不太明白的原因是为什么它永远无法重新回到原点:我在负载均衡器后面的所有4个应用服务器上无限期地看到这种波动.

这是我的PHP-fpm池配置:

[www]
user = www-data
group = www-data
listen = /var/run/PHP5-fpm.sock
listen.group = www-data
listen.mode = 0660
pm = dynamic
pm.max_children = 100
pm.start_servers = 40
pm.min_spare_servers = 40
pm.max_spare_servers = 100
pm.max_requests = 10000

我已经确认这不是数据库的问题 – 在看到MysqL读取从属数量增加一倍之后,我看到了完全相同的行为.

是什么造成的?我怎么能阻止它?

编辑:

这是一张图表,展示了我所看到的.请注意,失败率通常会随着user_count达到峰值而出现峰值,然后逐渐降低.

你的记忆管理怎么样?最后几周,我做了一些模拟测试,并将一台服务器带到了极限.我看到了很多内存的变化.在我的情况下,大量数据被带入交换而不是RAM来处理负载.经过一次测试后,我得到了一个真正奇怪的结果,没有使用任何RAM,完成所有内容都进入交换.也许这就是以下请求放慢速度的原因.

这是一个示例图像,我的交换在负载测试后的样子

猜你在找的PHP相关文章