红联Linux门户
Linux帮助

PHP的异步并行扩展Swoole发布1.7版本

发布时间:2014-04-17 16:41:22来源:红联作者:empast
Swoole 1.7.0 发布了,该版本主要改进内容包括:

reactor线程与writer线程合并

对send优化,加入out_buffer机制

增加AIO异步读写文件的API

增加DNS异步查询函数

swoole_client在php-fpm或apache mod_php下支持长连接

增加非Server模式下的异步定时器支持

定时器优化

增加sendfile支持

onReceive的data变量使用引用方式,减少一次内存复制

消息队列模式增加定时器的支持

增加signalfd的支持,使信号事件也加入到Reactor

Swoole介绍

Swoole是一个PHP的异步并行扩展。基于Swoole,PHP就可以开发类似Node.js、Golang,基于全异步事件驱动的高性能网络程序。

Swoole提供了全套的异步API,包括异步MySQL查询、毫秒定时器、异步文件读写、DNS查询、异步TCP/UDP客户端等。

与Node.js不同,Swoole具有多线程Reactor和多进程Worker可以很好的利用多核。所以在多核的机器上,IO处理能是Node.js的数倍。另外Swoole的工作进程中事件回调可以是异步方式,也可以同步。

Swoole中使用了很多Linux内核新特性来增强系统功能和性能,如sendfile、eventfd、timerfd、signalfd等。

Swoole中使用了很多CPU原子性来实现多线程无锁编程,实现了高效的并行化运行。在swoole中工作进程可以很轻松地遍历/发送数据到所有TCP连接,而且无需担心数据同步和加锁。

Swoole项目地址

GitHub:https://github.com/matyhtf/swoole

网站首页:http://www.swoole.com/

Pecl首页:http://pecl.php.net/package/swoole

来自:开源中国社区
文章评论

共有 0 条评论