swoole要求php版本,swoole哪个版本⽀持php5
Swoole 2.0正式版发布了。2.0版本最⼤的更新是增加了对协程(Coroutine)的⽀持。正式版已同时⽀持PHP5和PHP7。基于Swoole2.0协程PHP开发者可以已同步的⽅式编写代码,底层⾃动进⾏协程调度,转变为异步IO。
解决了传统异步编程嵌套回调的问题。 (推荐学习:swoole视频教程)
与Node.js(ES6+)、Python等语⾔使⽤yield/generator、async/await的实现⽅式相⽐,Swoole协程⽆需修改代码添加额外的关键词。
与Go语⾔的goroutine相⽐,Swoole协程是内置式的,应⽤层代码⽆需添加go关键词启动协程,只需要使⽤封装好的协程客户端即可,使⽤更简单。
另外Swoole协程的IO组件在底层内置了超时机制,不需要使⽤复杂的select/chan/timer实现客户端超时。
⽬前Swoole底层内置的协程客户端组件包括:udpclient、tcpclient、httpclient、redisclient、mysqlclient,基本涵盖了开发者常⽤的⼏种通信协议。
协程组件只能在服务器的onConnect、onRequest、onReceive、onMessage 回调函数中使⽤。
使⽤⽰例$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);
/**
php支持多线程吗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 {
$response->end(" recv failed error : {$tcp_cli->errCode}");
}
});
$server->start();
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论