对swoole和workerman的一些看法

2,717 阅读12分钟

虽说都在唱衰php,但正常头脑的 coder 都知道,php只是完成工作、实现目标的工具,不论使用 汇编、c、c++、c#、java、go、js、rust、php、python 或任何其他语言,只要能满足 高效率开发、符合预期需求、性能够用、安全达标,那就是个好工具,蓝猫是猫、橘猫是猫,逮住耗子(会卖萌)就是好猫。

再说 php8 性能丝毫不差,尤其是加持常驻内存和协程后,开发效率那是嗖嗖嗖的,成本却很低,性价比自然杠杠滴。开发一时爽 维护火葬场吗,NO,php8开启强类型,配合团队规范,维护不是问题。所谓安全这个锅更和语言无关。

swoole和workerman在国内用的比较多,两者都非常优秀。

Swoole: PHP 协程框架

swoole是c/c++写的网络通讯扩展,Swoole 使 PHP 开发人员可以编写高性能高并发的 TCP、UDP、Unix Socket、HTTP、 WebSocket 等服务,让 PHP 不再局限于 Web 领域。

workerman: PHP应用容器

workerman 是纯php写的网络框架.支持TCP长连接,支持Websocket、HTTP等协议,支持自定义协议,拥有异步Mysql、异步Redis、异步Http、MQTT物联网客户端、异步消息队列等众多高性能组件。

两者功能类似,均可以广泛应用于互联网、移动通信、云计算、 网络游戏、物联网(IOT)、车联网、智能家居等领域。

那究竟哪个更好一些?我们该如何选择呢?摘选一些网友的评论,供参考。

0. 部署方便性

swoole: 如果手动编译 swoole 扩展的话,相对 workerman 来说,是比较复杂的,但 swoole团队 出了一个 swoole-cli 静态编译版,即集成了 php8.1+swoole+很多扩展 的单文件php(linux下、win下是绿色解压包)。部署非常方便,甚至连php都不需要单独部署了,直接下载swoole-cli,重命名为 php ,然后无缝替代 官方php8.1。强烈推荐使用(详细说明 wenda.swoole.com/detail/1088…

window版swoole-cli下载地址:wenda-1252906962.file.myqcloud.com/dist/swoole…

linux x64版 swoole-cli下载地址:wenda-1252906962.file.myqcloud.com/dist/swoole…

mac版 swoole-cli 载地址:wenda-1252906962.file.myqcloud.com/dist/swoole…

swoole-cli github github.com/swoole/swoo…

swoole-cli 全部版本下载地址 www.swoole.com/download

swoole-cli 详细说明 wenda.swoole.com/detail/1088…

workermn: 正常安装 php 环境后,下载 workerman 压缩包解压即可,或者 composer require workerman/workerman 安装。当然也可以用 swoole-cli 来运行 workerman

1.学习成本考虑

网友评价1:

如果你之前没有过网络编程或多进程开发经验的话,我的建议是你先从workerman入手,毕竟workerman是纯PHP代码实现的,你在深入理解其原理和处理问题时不会有太大的障碍。

通过对workerman的深入学习,你可以学习到网络编程相关的基础知识,这种程序是如何设计实现的,当中需要注意哪些细节。你还可以学习到如何开发多进程程序,进程间如何管理和通信。当你这些了解清楚后,你再过渡到swoole会觉得门槛没有那么高,如果你直接上手就swoole的话,至少进程间的管理和通信都需要你自己去实现,你可能连思路都没有。由浅入深,先从基础开始,再向高级进阶。

网友评价2:

swoole 是作为 php 的扩展,不依赖其他扩展,底层是 c,程序中直接调用,性能较高。workman 是用原生 php,依赖其他扩展,需要下载源码包。前者可以理解为 swoole 是提供给 php 的 api ,原生度比较高,所以没有封装实践中的 业务逻辑,需要自己开发。后者对某种业务需求有封装,更容易上手。本人曾经学习 swoole 个把月,感觉比较难驾驭,需要掌握比较多的基础知识,实际工作中运用较少,但是感觉值得学习。总之,用哪个看用来做什么,大众需求, workman 可能开发成本更低,有些特定需求,也可以研究研究 swoole。

网友评价3:

推荐 workerman!swoole 那套直接 c 拓展的不适合进阶新手,新手要的是渐进式,稳定性,循序渐进,先掌握一个范式,再一步一步来。workerman 也出了官方 web 框架 webman,压测排名在 swoole 之上,毫不夸张的说,workerman 目前是最成熟,成本最低的 PHP 解决方案,门槛还低。

网友评价4:

swoole是由C语言开发的php扩展类,就性能而言swoole具有优势,对PHP程序员有一定的要求,了解底层通信服务开发,需要学习的知识比较多,swoole一般适合老手开发。workerman纯php开发框架,很容易上手。号称只要你会php,你就使用它开发socket应用服务。建议先学习workerman,在学习swoole。

网友评价5:

workerman是纯PHP实现的常驻内存框架,同步阻塞模式,先学习这个方便对常驻内存模式有一定的了解,对内存泄露有一定的了解。workerman熟悉后再来学习swoole,swoole除了常驻内存,还有就是协程,这个在传统开发模式中是不存在的。协程类似线程,开发过程中需要主要各个协程中间的数据之间的操作问题。

我认为,workerman的学习成本更低,尤其是做web开发,webman和tp很相似,几乎从tp无缝迁移,没有任何多余的心智负担。

官方文档 www.workerman.net/doc/workerm… 很不错,清晰详细,示例很多

官方论坛 www.workerman.net/questions 非常活跃,绝大多数问题都能快速得到有效解答,框架作者 walkor 几乎每天都在论坛亲自解答,即便是非常初级的新手问题,也很耐心。

swoole的文档也不错,但对没有多进程、多线程编程经验的新手来说,上手有点困难,心智负担有些重,新手直接阅读文档,可能事倍功半。

2.应用范围


网友评价1:

我的一个开源项目用的就是 workerman 项目查看,依赖的环境比较少,开发难度小。如果不是上万的并发建议 workerman。但是我的经验表明 95% 的项目都不会有上万的并发。初学者我也建议用 workerman。swoole 你也可以同时学习,毕竟协程更节省硬件资源。还有就是 workerman 的作者超级有耐心回复各种问题,从来没有见过如此热心的

网友评价2:

swoole 是扩展,在使用 workerman 的同时,若你需要用到 swoole 的东西,同样也可以使用,而且从应用角度来说,我更喜欢 workerman gateworker。这些能直接解决很多问题,避免从基础进行研究

网友评价3:

workerman 更简单稳定,考虑了很久还是用workerman , swoole目前太乱了,生产环境稳定毕竟用的php原生东西 swoole玩了一段时间 坑太多了。

网友评价4:

Swoole的部署折腾了我一个礼拜,终于能跑通了,再想想还要很多第三方类库和扩展要继续折腾,还是算了。 Gatewayworker直接用XFTP工具把文件夹拖进去,然后start就好了,省心多了。 对于我这种小白来说,不考虑什么集群,什么上千万的并发,什么容器,我选Gatewaywroker。

网友评价5:

个人觉得swoole和workerman都能解决高并发io问题,但用了两种思路。不存在谁高级,谁低级。用C写PHP扩展解决问题就显得有多牛逼了,那可不见得。用C写PHP扩展,对比的应该是C程序员,而不是PHP程序员,那么C语言就比PHP语言高级,那这么说的话大家都用C开发网站得了呗。

两者应用范围是重叠的,不管是web还是物联网,都能胜任,本质上 swoole是c/c++的网络框架,而workerman是基于 pcntl多进程扩展 的网络框架

3. 性能考虑


网友评价1:

说swoole比workerman好,是因为评论的人没用过workerman,他只是片面的认为c++比php快,就认为其程序框架也是这样。

然而,workerman只载入解析一次php文件,然后便常驻内存,极大的减少了磁盘IO及PHP中请求初始化、创建执行环境、词法解析、语法解析、编译opcode、请求关闭等诸多耗时过程。所以纯碎从语言层面比较,更应该是c++和机器码的区别。

两者都是非常优秀的开源框架,只是看自己更喜欢折腾c++还是php罢了

网友评价2:

其实性能差不多,workerman更稳定,发现问题,更易维护

网友评价3:

从跑分来每个指标workerman都比swoole略高一些,总体来看看swoole和workerman结果差不多,不过这仅仅是跑分,真实效果还是要看实际项目。

网友评价4:

我觉得是不是都搞错了对比双方。workman是PHP写的,但本质是用pcntl等扩展实现了功能,swoole是C/C++写的,但实际还是以PHP扩展形式出现,所以其实都是PHP扩展。

所以其实比的是pcntl等扩展和swoole扩展的效能 所以workman不慢不是很正常么?

网友评价5:

www.techempower.com/benchmarks/… 这个是国外权威压测机构 www.techempower.com 第19轮压测,带数据库业务的,swoole用了数据库连接池+协程,workerman就是原始php mysql阻塞用法,结论仍然是二者性能差别不大,各项性能指标均是workerman好些,尤其是plaintext,比swoole高35%左右。

当然,这个只是压测结果,仅有部分参考意义,不代表现实项目最终结果。

两者性能并没有太明显差别,同样常驻内存,同样多进程。swoole有协程加持,某些应用场景下,可能并发性能更好。

4.生态考虑


网友评价1:

因为项目需要, 智能家居一类的, 本来准备用C做, 想想swoole和workerman很火很成熟, 不少稳定应用场景了, 想想为什么不能用这俩试一下呢? C水平有限, 用PHP能满足需求多好?

所以今天大概了解了下swoole和workerman, 初步映象对swoole没有想象中那么好, 反而workerman让我非常惊艳...

再说workerman:

workerman例子很完善, 讲解详细, 比swoole好不少.

重要一点是用纯PHP就能实现如此之高性能php-cli在php5.3时代就已经成熟了, 一直没时间在此基础做大型项目, 老是感觉性能不行, workerman却让我惊艳.

workerman用到的pcntl, posix两个扩展也是PHP自带的扩展, 默认会编译进去, streams系列函数是PHP自带函数, 更没有扩展之说. 所以某人说的太夸张了. 并不需要不成熟第三方扩展, 这两个扩展是非常成熟的扩展, 稳定到进入PHP默认开启的扩展, streams甚至进入PHP基本函数了.

如果为了像Nginx一样开启Kqueue和Epoll则需要安装和swoole一样的pecl扩展:pecl-event. 此扩展也非常稳定了. 这些都是基本扩展, 不会不稳定更不会PHP7,PHP8不支持. streams, pcntl, posix, pecl-event其实对底层的浅封装, 性能没问题, 看你怎么用, 会不会用, workerman就用的很好。

最后说一下:

我不同意韩天峰说的swoole需要比较高超水平, 其实两者都是给你封装好, 拿来用就行. 但如果出现问题workerman可以去了解协议, 修改封装的PHP代码. swoole就没法修改了, 至少你要会C语言才能去修改, 这是很多phper不擅长的.

我暂时决定用workerman了, 因为出现上述那种问题我可以自己修改workerman的PHP代码解决. 而swoole是用C重新实现的, 很多坑要去完善, 而社区也不活跃, 没人理睬, 而我没精力去查C代码找原因. 发现很多人也是试验了swoole后发现还是workerman稳定些, 所以改用workerman了. 其实我还是希望swoole能快速发展的完善些.

以上纯属个人观点, 一切都是为了PHP能健康快速发展下去, 希望swoole越来越好...

网友评价2:

其实都差不多,如果直接基于swoole或者workerman开发,都不算容易。

但现在都可以基于框架开发,比如hyperf和webman,当然,如果你也试试imi,你会发现他俩在使用的时候,基本没区别。 Imi说,反正我都支持!

网友评价3:

workerman的文档做的非常好,例子也丰富很多,我觉得workerman更容易上手,而且比swoole稳定很多

网友评价4:

官方方案fpm+opcache+jit+长连接,或者workerman,稳如老狗,官方方案,有问题自己轻松解决。

实在没有办法可以引入第三方语言综合即可。如果你关注PHP官方的协程或者异步方案,可以浏览下Amphp作者推出的Fiber扩展,已经进入rfc阶段。

网友评价5:

workerman更符合php的精神,作为一个workerman一年多使用者,坚决支持workerman。而且workor真的特别认真,新手问题在论坛回复的也很及时,对新手友好度max。


虽然不会固守一种语言,但php还是很不错的,开发效率很高,还是希望php能像js一样,焕发第二春。 尤其是 swoole-cli 非常棒,跨平台部署很方便,linux上直接单文件命令执行。