V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
seth19960929
V2EX  ›  PHP

PHP -roadrunner 压力测试调优配置

  •  
  •   seth19960929 · 11 天前 · 560 次点击

    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 能达到这个程度

    4 条回复    2024-04-24 21:18:00 +08:00
    ywisax
        1
    ywisax  
       11 天前
    最好说明下 /api/welcome 的逻辑。这个结果不符合开发者对 roadrunner 的预期。
    另外跟纯用 golang 写网络业务的接口对比也不合适。laravel+roadrunner 对比的应该是 gin+gorm 这类方案。
    gongquanlin
        2
    gongquanlin  
       11 天前
    这种小鸡能干啥,没有太大意义呀
    seth19960929
        3
    seth19960929  
    OP
       11 天前
    @ywisax #1 本文并不是要说明 PHP 性能, 而是为了测试出合理的配置
    seth19960929
        4
    seth19960929  
    OP
       11 天前
    @gongquanlin #2 什么不能干, 测试是一个, 正式直接扩容成 100 个啊
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   772 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 86ms · UTC 22:05 · PVG 06:05 · LAX 15:05 · JFK 18:05
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.