Swoole
虽然在2016
年就支持了协程特性,但因为底层是基于setjmp/longjmp
实现的stackless
方案。所以在某些场景下,如call_user_func
、array_map
、__destruct
中没法使用协程。大型应用程序中逻辑很是复杂,多人协做的团队中,开发者很容易踩到坑。在禁止场景中使用协程API
会出现各类莫名其妙的问题发生。限制了协程的应用范围。php
新版本4.0
基于boost.context 1.60
汇编代码实现了全新的协程内核。在保存PHP
函数调用栈的基础上,增长了C
栈的上下文存储。实现了对全部PHP
语法的支持。如今在任意PHP
的函数,包括call_user_func
、反射、魔术方法、array_map
中都可使用协程。git
如今能够在PHP
代码中任意位置使用协程,开发者再也不须要担忧使用场景问题。4.0
版本咱们与SwooleDistributed
/Swoft
/EasySwoole
等框架做者进行了紧密合做,在大量项目中进行了灰度试用。稳定性和健壮性均已达到工业级的水准。彻底可用于大型项目的生产环境中。github
go(function() { array_map("test", array("func start\n")); echo "co end\n"; }); function test($p) { echo $p; co::sleep(1); echo "func end \n"; }
4.0
分支使用了C++11
标准,建议使用gcc-4.8
或更高版本。
新版本中底层对全局变量进行了隔离,如今可使用Swoole\Process
建立多个Swoole\Server
实例了。浏览器
for ($i = 0; $i < 2; $i++) { $p = new swoole_process(function () use ($i) { $port = 9501 + $i; $http = new swoole_http_server("127.0.0.1", $port); $http->on("start", function ($server) use ($port) { echo "Swoole http server is started at http://127.0.0.1:{$port}\n"; }); $http->on("request", function ($request, $response) { $response->header("Content-Type", "text/plain"); $response->end("Hello World\n"); }); $http->start(); }, false, false); $p->start(); }
http2
服务器没法向Chrome
浏览器客户端发送超过16K
数据的问题BASE
模式下Task
进程没法重启的问题Channel->peek
方法,用于窥视数据Server->pause/resume
在SWOOLE_PROCESS
下没法使用的问题Linux AIO
,如今不管如何设置都使用线程池实现异步文件IO
MySQL
存储过程