swoole会使php流行吗,为什么PHP程序员应该学习使用Swoole

最近两个月一直在研究 Swoole,研究成果即将在6.21正式开源发布,这段时间没有来水文章,趁着今天放假来水水吧。

借助这篇文章,我希望能够把 Swoole 安利给更多人。虽然 Swoole 可能目前定位是一些高级 phper 的玩具,让中低级望而生畏,可能对一些应用场景也一脸懵逼,但其实没这么难的。

在 Swoole 官网的自我介绍是“面向生产环境的 PHP 异步网络通信引擎”,首先 Swoole 它是一个网络应用的开发工具,它支持 Http、TCP、UDP、WebSocket。

Swoole 和我们传统的 PHP 开发差别是有的,需要理解的概念也是有的。使用目前一些基于 Swoole 的框架开发的话,从开发习惯上和传统的TP、LV 框架相差不多。

那为什么要使用 Swoole?

宇润认为有以下几点:

常驻内存,避免重复加载带来的性能损耗,提升海量性能

协程异步,提高对 I/O 密集型场景并发处理能力(如:微信开发、支付、登录等)

方便地开发 Http、WebSocket、TCP、UDP 等应用,可以与硬件通信

PHP 高性能微服务架构成为现实

10年架构师领你架构-成长之路-(附面试题(含答案))

常驻内存

目前传统 PHP框架,在处理每个请求之前,都要做一遍加载框架文件、配置的操作。这可能已经成为性能问题的一大原因,而使用 Swoole 则没有这个问题,一次加载多次使用。

协程

如下图所示,这是同一个线程处理并发请求的场景,比如你某个接口中需要调用其它 api 接口或读写大文件,传统同步阻塞和协程异步的优势就体现了出来。

[图片上传失败...(image-3f5bfd-1600346322180)]

说到协程,就得先简单说说进程和线程,众所周知进程是很占用资源的,为了处理请求大量创建进程肯定是得不偿失的。而多线程应用就比较多了,在 CPU 层面有几个核心就会执行几个任务,线程一旦创建的多了,就会有线程调度的损耗。

协程是在单线程基础上实现的,它可以最大限度利用 CPU 资源,而不会在等待 I/O 时白白浪费。当然,协程数越多占用的内存也就越多,不过这个是可以接受的,相比进程和线程,占用的资源是相对较少的。

使用协程时,遇到读写文件、请求接口等场景,会自动挂起协程,把 CPU 让给其它协程执行任务,这样可以提升单线程的 CPU 资源利用率,减少浪费,从而提高性能。

感谢大家一直来支持,这是我准备的1000粉丝福利

协程代码示例:

|

1234567891011121314151617181920212223242526

|

math?formula=time%20%3D%20microtime(true)%3B%2F%2F%20%E5%88%9B%E5%BB%BA10%E4%B8%AA%E5%8D%8F%E7%A8%8Bfor(i = 0;

math?formula=i%20%3C%2010%3B%20%2B%2Bi){ // 创建协程 go(function() use(

math?formula=i)%7B%20co%3A%3Asleep(1.0)%3B%20%2F%2F%20%E6%A8%A1%E6%8B%9F%E8%AF%B7%E6%B1%82%E6%8E%A5%E5%8F%A3%E3%80%81%E8%AF%BB%E5%86%99%E6%96%87%E4%BB%B6%E7%AD%89I%2FO%20echoi, PHP_EOL; });}swoole_event_wait();echo 'co time:', microtime(true) -

math?formula=time%2C%20'%20s'%2C%20PHP_EOL%3B%20%2F%2F%20%E5%90%8C%E6%AD%A5time = microtime(true);// 创建10个协程for(

math?formula=i%20%3D%200%3Bi < 10; ++

math?formula=i)%7B%20sleep(1)%3B%20%2F%2F%20%E6%A8%A1%E6%8B%9F%E8%AF%B7%E6%B1%82%E6%8E%A5%E5%8F%A3%E3%80%81%E8%AF%BB%E5%86%99%E6%96%87%E4%BB%B6%E7%AD%89I%2FO%20echoi, PHP_EOL;}echo 'sync time:', microtime(true) - $time, ' s', PHP_EOL;

|

运行结果:

|

12345678910111213141516171819202122

|

0987654321co time:1.0087130069733 s0123456789sync time:10.010055065155 s

|

从上面结果可以看出,协程方式执行并不是顺序的,性能更高,在sleep时会把当前线程的任务执行权交给其他协程。

创建 Http 服务

其实也没想象中的难,看代码:

|

12345

|

math?formula=http%20%3D%20new%20swoole_http_server(%22127.0.0.1%22%2C%209501)%3Bhttp->on('request', function (

math?formula=request%2Cresponse) {

math?formula=response-%3Eend(%22%3Ch1%3EHello%20Swoole.%20%23%22.rand(1000%2C%209999).%22%3C%2Fh1%3E%22)%3B%7D)%3Bhttp->start();

|

微服务

Tars是腾讯从2008年到今天一直在使用的后台逻辑层的统一应用框架TAF(Total Application Framework),目前支持C++,Java,PHP,Nodejs语言。该框架为用户提供了涉及到开发、运维、以及测试的一整套解决方案,帮助一个产品或者服务快速开发、部署、测试、上线。 它集可扩展协议编解码、高性能RPC通信框架、名字路由与发现、发布监控、日志统计、配置管理等于一体,通过它可以快速用微服务的方式构建自己的稳定可靠的分布式应用,并实现完整有效的服务治理。

大厂2000道面试题(含答案)

喜欢我的文章就关注我吧,持续更新中.....

以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要的可以点击进入暗号:知乎。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值