Swoole 4.0 正式版发布,面向生产环境的 PHP 协程引擎

Swoole虽然在2016年就支持了协程特性,但由于底层是基于setjmp/longjmp实现的stackless方案。因此在某些场景下,如call_user_func、array_map、__destruct中无法使用协程。大型应用程序中逻辑非常复杂,多人协作的团队中,开发者很容易踩到坑。在禁止场景中使用协程API会出现各种莫名其妙的问题发生。限制了协程的应用范围。

新版本4.0基于boost.context 1.60汇编代码实现了全新的协程内核。在保存PHP函数调用栈的基础上,增加了C栈的上下文存储。实现了对所有PHP语法的支持。现在在任意PHP的函数,包括call_user_func、反射、魔术方法、array_map中均可使用协程。
现在可以在PHP代码中任意位置使用协程,开发者不再需要担心使用场景问题。4.0版本我们与SwooleDistributed/Swoft/EasySwoole等框架作者进行了紧密合作,在大量项目中进行了灰度试用。稳定性和健壮性均已达到工业级的水准。完全可用于大型项目的生产环境中。

1
2
3
4
5
6
7
8
9
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实例了。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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存储过程

下载 4.0

坚持原创技术分享,您的支持将鼓励我继续创作!