php携程源码,Swoole2.0协程的使用和源码解读

聊聊Swoole2.0协程

Swoole 2.0正式版发布了。2.0版本最大的更新是增加了对协程(Coroutine)的支持。正式版已同时支持PHP5和PHP7。基于Swoole2.0协程PHP开发者可以已同步的方式编写代码,底层自动进行协程调度,转变为异步IO。解决了传统异步编程嵌套回调的问题。

目前Swoole底层内置的协程客户端组件包括:udpclient、tcpclient、httpclient、redisclient、mysqlclient,基本涵盖了开发者常用的几种通信协议。协程组件只能在服务器的onConnect、onRequest、onReceive、onMessage 回调函数中使用。

注意,Swoole 2.0.5以前的版本还是灰度测试版本,可能会存在问题。 beta是因为协程是全新的版本。

协程的使用示例

/**

只有在Server中才能使用协程。包括 http server,websocket server 和 server。

*/

$server = new Swoole\Http\Server('127.0.0.1', 9501);

/**

触发on request事件时,SWOOLE会开辟一个协程栈,对协程栈进行初始化

*/

$server->on('Request', function ($request, $response) {

$tcp_cli = new Swoole\Coroutine\Client(SWOOLE_SOCK_TCP);

/**

client在调用connect函数后,SWOOLE会将PHP上下文信息保存到当前栈内

然后将协程挂起,待确认连接成功后,触发epoll事件,然后协程切换

恢复PHP上下文信息,返回结果,继续执行PHP代码

*/

if ($tcp_cli->connect('127.0.0.1', 9906) === false) {

$response->end("connect server failed.");

return;

}

$tcp_cli->send('test for the coro');

/**

client在调用recv函数后,SWOOLE会将PHP上下文信息保存到当前栈内

然后将协程挂起待后端svr回包,触发epoll事件,然后协程切换

恢复PHP上下文信息,返回结果,继续执行PHP代码

如果后端在设定的超时时间内,未能回包,返回false

client的errCode定为110

*/

$ret = $tcp_cli->recv(100);

$tcp_cli->close();

if ($ret) {

$response->end(" swoole response is ok");

} else 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值