PHP程序员学习使用Swoole的理由


Posted in PHP onJune 24, 2018

最近两个月一直在研究 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 高性能微服务架构成为现实

常驻内存

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

协程

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

PHP程序员学习使用Swoole的理由

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

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

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

协程代码示例:

<?php
use Swoole\Coroutine as co;
 
// 协程
$time = microtime(true);
// 创建10个协程
for($i = 0; $i < 10; ++$i)
{
 // 创建协程
 go(function() use($i){
  co::sleep(1.0); // 模拟请求接口、读写文件等I/O
  echo $i, PHP_EOL;
 });
}
swoole_event_wait();
echo 'co time:', microtime(true) - $time, ' s', PHP_EOL;
 
// 同步
$time = microtime(true);
// 创建10个协程
for($i = 0; $i < 10; ++$i)
{
 sleep(1); // 模拟请求接口、读写文件等I/O
 echo $i, PHP_EOL;
}
echo 'sync time:', microtime(true) - $time, ' s', PHP_EOL;

运行结果:

0
9
8
7
6
5
4
3
2
1
co time:1.0087130069733 s
0
1
2
3
4
5
6
7
8
9
sync time:10.010055065155 s

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

创建 Http 服务

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

$http = new swoole_http_server("127.0.0.1", 9501);
$http->on('request', function ($request, $response) {
 $response->end("<h1>Hello Swoole. #".rand(1000, 9999)."</h1>");
});
$http->start();

微服务

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

PHP 相关文章推荐
PHP概述.
Oct 09 PHP
自动分页的不完整解决方案
Jan 12 PHP
phpmyadmin中配置文件现在需要绝密的短语密码的解决方法
Feb 11 PHP
php 转换字符串编码 iconv与mb_convert_encoding的区别说明
Nov 10 PHP
PHP中的cookie不用刷新就生效的方法
Feb 04 PHP
php中动态修改ini配置
Oct 14 PHP
PHP图像处理之imagecreate、imagedestroy函数介绍
Nov 19 PHP
PHP+原生态ajax实现的省市联动功能详解
Aug 15 PHP
PHP基于递归实现的约瑟夫环算法示例
Aug 27 PHP
PHP实现模拟http请求的方法分析
Dec 20 PHP
Laravel 在views中加载公共页面的实现代码
Oct 22 PHP
深入浅析安装PhpStorm并激活的步骤详解
Sep 17 PHP
PHP实现的装箱算法示例
Jun 23 #PHP
PHP基于curl模拟post提交json数据示例
Jun 22 #PHP
PHP获取日期对应星期、一周日期、星期开始与结束日期的方法
Jun 22 #PHP
PHP实现将base64编码字符串转换成图片示例
Jun 22 #PHP
PHP实现正则匹配所有括号中的内容
Jun 22 #PHP
PHP实现 APP端微信支付功能
Jun 22 #PHP
thinkPHP实现基于ajax的评论回复功能
Jun 22 #PHP
You might like
php session_start()关于Cannot send session cache limiter - headers already sent错误解决方法
2009/11/27 PHP
php Ubb代码编辑器函数代码
2012/07/05 PHP
关于php程序报date()警告的处理(date_default_timezone_set)
2013/10/22 PHP
使用PHP uniqid函数生成唯一ID
2015/11/18 PHP
Laravel的throttle中间件失效问题解决方法
2016/10/09 PHP
php mysql操作mysql_connect连接数据库实例详解
2016/12/26 PHP
javascript的trim,ltrim,rtrim自定义函数
2008/09/21 Javascript
js或css实现滚动广告的几种方案
2010/01/28 Javascript
js下用层来实现select的title提示属性
2010/02/23 Javascript
js中的数组Array定义与sort方法使用示例
2013/08/29 Javascript
JavaScript设计模式之单件模式介绍
2014/12/28 Javascript
JavaScript中的标签语句用法分析
2015/02/10 Javascript
将JavaScript的jQuery库中表单转化为JSON对象的方法
2015/11/17 Javascript
实例详解ECMAScript5中新增的Array方法
2016/04/05 Javascript
Node.js中防止错误导致的进程阻塞的方法
2016/08/11 Javascript
jQuery插件echarts实现的单折线图效果示例【附demo源码下载】
2017/03/04 Javascript
一步步教你利用Docker设置Node.js
2018/11/20 Javascript
Element-UI中Upload上传文件前端缓存处理示例
2019/02/21 Javascript
浅谈微信小程序列表埋点曝光指南
2019/10/15 Javascript
逐行分析鸿蒙系统的 JavaScript 框架(推荐)
2020/09/17 Javascript
如何利用JS将手机号中间四位变成*号
2020/09/29 Javascript
基于Python实现通过微信搜索功能查看谁把你删除了
2016/01/27 Python
Android应用开发中Action bar编写的入门教程
2016/02/26 Python
python按综合、销量排序抓取100页的淘宝商品列表信息
2018/02/24 Python
Python操作Oracle数据库的简单方法和封装类实例
2018/05/07 Python
Python实现分段线性插值
2018/12/17 Python
Python Pandas 如何shuffle(打乱)数据
2019/07/30 Python
python实现将字符串中的数字提取出来然后求和
2020/04/02 Python
使用tensorflow进行音乐类型的分类
2020/08/14 Python
托管代码(Managed Code)和非托管代码(Unmanaged Code)有什么区别
2014/09/29 面试题
Tomcat的缺省是多少,怎么修改
2014/04/09 面试题
求职自荐信
2013/12/14 职场文书
企业宣传标语
2014/06/09 职场文书
银行贷款收入证明
2014/10/17 职场文书
讲座通知范文
2015/04/23 职场文书
2016年员工年度考核评语
2015/12/02 职场文书