PHP-roadrunner 压力测试调优配置

pod 配置

cpu memory
0.5 512M

性能测试工具:

https://pts.console.aliyun.com/

并发 测试时间 压力来源 压测接口
100 2 分钟 公网 /api/welcome

ps: 并发100是先压测之后得到pod能承受的数量 (200并发无报错但是RT大大增加, 再多就开始报错了)

启动服务:

roadrunner 运行原理

image-20240424-054522.png

laraveloctane内置支持roadrunner, 所以可以通过以下命令启动HTTP服务

php artisan octane:start --server=roadrunner --host=0.0.0.0 --port=8080 --rpc-port=6001 --workers=1 --log-level=warn
--max-requests=50000 --rr-config=/var/www/.rr.yaml

Copy

基础概念:

QPS(TPS) = 总请求数 / 时间(秒)

并发(是对于客户端的理解, 比如 100 并发) QPS (是对于服务端可以处理请求的速度), 两者并没有必然关系

测试列表:

官方的建议是 workers 数量等于 CPU 线程数

开启keep-alive可以提升 40% 性能

max-requests 无内存泄漏问题, 可以设置成 0 或者很大的一个值(此次测试过程设置为 50000)

workers max-requests 成功率 平均RT(ms) 总请求数 TPS(平均/峰值) 预览图
1 50000 100% 1378 8665 72/118
2 50000 100% 1090 10000 91/170
4 50000 100% 1307 9042 76/133
8 50000 99.16% (内存达到极限, 处理太慢超时错误) 2161 5501 46/78
2 500 93.68% (请求到达 500 重启) 1567 7508 65/174

性能负载图

  • CPU基本没什么变化, 内存是因为开多个woker会占用更多的内存

image-20240424-052711.png

经上所测在这个配置下我选择了使用 workers=2

Golang 压力测试

补一张Go程序0.5U128M * 150pod 的性能图, 何时 PHP 能达到这个程度

本作品采用《CC 协议》,转载必须注明作者和本文链接
当神不再是我们的信仰,那么信仰自己吧,努力让自己变好,不辜负自己的信仰!
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 15
skarner

建议OP有空可以用 webman 试试

看看 webman 能到什么程度

3个月前 评论
seth-shi (楼主) 3个月前

roadrunner 官方文档:在内存够用的情况下应该开尽可能多的 workers

Laravel

3个月前 评论
seth-shi (楼主) 3个月前
seth-shi (楼主) 3个月前
Aoyamakiri (作者) 3个月前
awk_us 3个月前
seth-shi (楼主) 3个月前
seth-shi (楼主) 3个月前
Aoyamakiri (作者) 3个月前
seth-shi (楼主) 3个月前
33qis 3个月前
seth-shi (楼主) 3个月前

:grin: 加上数据库的读写先,从某种角度来说,空测的意义不算特别大,如果是用空测,webman 应该是极快的。期待 LZ 加上真实业务场景的压测

3个月前 评论
seth-shi (楼主) 3个月前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!
未填写
文章
40
粉丝
157
喜欢
711
收藏
347
排名:30
访问:22.2 万
私信
所有博文
社区赞助商