前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PHP运行时性能基准测试

PHP运行时性能基准测试

作者头像
Tinywan
发布2024-07-05 12:48:42
850
发布2024-07-05 12:48:42
举报
文章被收录于专栏:开源技术小栈开源技术小栈

测试环境

  • 每个运行时在1或2个Docker容器中运行
  • 每个容器有1个CPU和1GB RAM
  • 负载测试工具位于同一Docker网络中

测试应用程序

Symfony提供了运行时组件。根据官方文档,它“从任何全局状态中提取引导逻辑,以确保应用程序可以在运行时运行,如”。这意味着,您可以使用任何您喜欢的运行时来开发应用程序,但在生产中运行最高性能。因此,我们不仅可以使用传统的服务器运行应用程序,还可以使用Swoole,AMPHP和ReactPHP等库。展望未来,最后两人被排除在竞争之外。

负载测试工具

K6用于运行负载测试。每个运行时运行3次,30秒内有10、100和1000个并发连接。

运行时

  • Apache(prefork模式)+ mod_php
  • Apache(事件模式)+ PHP-FPM
  • Nginx + PHP-FPM
  • Nginx Unit应用服务器
  • Nginx Unit应用服务器
  • Nginx + Roadrunner(fcgi模式)
  • FrankenPHP
  • FrankenPHP(worker模式)
  • Swoole

所有运行时都基于官方Docker镜像。如果不使用镜像,则在构建过程中将应用程序的代码复制到镜像中。PHP 8.3无处不在,除了Nginx Unit。2024年初,Nginx Unit支持的最高PHP版本为8.2。

不幸的是,我没有找到与Symfony 7兼容的最新版本的ReactPHP和AMPHP运行时。PHPPM GitHub和Dockerhub看起来都被抛弃了。

应用以下PHP和Symfony设置:

  • 使用php.ini-production(附带官方Docker容器)
  • 已启用Opcache
  • 启用JIT
  • 根据Symfony最佳实践配置preload
  • Composer自动加载器已优化
  • Symfony在生产模式下运行
  • 服务容器转储到单个文件
  • Symfony缓存在容器构建期间预热

应用程序代码以及容器配置可以在GitHub https://github.com/DimDev/php-runtimes-benchmark上找到。

结果

  • 001_Apache+mod_php和002_Apache + PHP-FPM显示了几乎相同的结果。
  • 003_Nginx+PHP-FPM在工作负载较低(并发10和100)时非常接近001_Apache+mod_php和002_Apache + PHP-FPM。
  • 003_Nginx+PHP-FPM在并发量为1000时,能够服务的请求数是Apache堆栈的2倍
  • 004_Nginx单元。首先-哇!!它比传统和最流行的003_Nginx+PHP-FPM快3倍
  • 我不认为005_Roadrunner和006_Nginx+Roadrunner之间有很大的区别
  • 尽管如此,基于Roadrunner的堆栈比003_Nginx+PHP-FPM快2倍以上
  • 007_FrankenPHP(非工作模式)从性能角度来看非常接近003_Nginx+PHP-FPM
  • 008_FrankenPHP(worker mode). Double WOW!我不相信从第一次尝试和运行负载测试3或4倍。因此,当发送1000个并发请求时,FrankenPHP(工人模式)比Nginx+PHP-FPM快10倍。同时,也面临着一个问题。无法用php-ini. production启动容器。
  • 009_swoole -也是双重WOW!.几乎与008_FrankenPHP(wm)相同的速度。非常快。但是,请记住,您的代码应该调整为与Swoole一起运行。对于Symfony,我们有一个bundle,它扩展了symfony/runtime组件。

个人观点

  • FrankenPHP -惊人的工作,第一个候选人成为PHP世界的标准事实上。
  • Swoole -我希望它是开箱即用(但禁用)的PHP扩展。
  • Nginx Unit -我个人的选择。尽管它不支持HTTP 2和传统Nginx提供的许多其他功能,但它非常容易配置,轻便,快速。
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-06-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 开源技术小栈 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档