swoole-1.7.7 发布,内置Http服务器性能是Node.js的12倍

PHP的异步并发扩展swoole发布了 1.7.7 版本,此版本主要有:

单次定时器

swoole之前的版本仅支持间隔时间的固定定时器,1.7.7新增了单次定时器接口,可以指定在当前时间之后的n毫秒内执行一段代码。

swoole_timer_after(500, function(){
     echo "Hello Swoole\n";
}); //500ms

在服务器端程序中可以调用swoole_server对象的after方法。

$server->on('receive', function($server, $fd, $from_id, $data(){
    $server->after(2000, function(){
        echo "timeout\n";
    });
}));

内置Http服务器

在此版本中swoole内部集成了一个Http服务器,由底层的C代码解析Http协议。得益于swoole的多线程Reactor+多进程模型,swoole内置Http服务器的性能非常好。通过使用apache bench工具进行压测,性能是node.js的12倍,php-fpm的6倍,Go语言内置的Http服务器的1.42倍。

压测方法:

ab -c 200 -n 200000 -k http://127.0.0.1:9501/

硬件环境:

Inter Core I5 3.2G * 4核 + 8G内存

QPS对比:

Golang Http Node.js Httpphp-fpmswoole-http-server
82037.759684.1517622.74117029.94

压测采用的版本:

压测使用的代码:

均取自与官方提供的最简示例。

注:性能测试报告仅作参考,测试结果并不代表实际项目数据。

Swoole是一个PHP的C扩展,可用来开发PHP的高性能高并发TCP/UDP Server。Swoole的网络IO部分基于epoll/kqueue事件循环,是全异步非阻塞的。 业务逻辑部分使用多进程同步阻塞方式来运行。这样既保证了Server能够应对高并发和大量TCP连接。又保证业务代码仍然可以简单的编写。

Swoole与Node.js相比更强大,支持同步/异步、多进程并行,Swoole提供了进程生命周期管理、内存保护机制,开发者无需考虑底层细节,专注于业务逻辑和功能的开发。

Swoole的网络事件处理是多线程的,可以充分利用多核。而Node.js是单进程单线程的。使用官方提供的EchoServer在多核环境下压测。Swoole的处理能力比node.js高出数倍。



新闻来源:swoole-1.7.7 发布,Http 服务器性能大幅提升