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

来源:互联网 发布:酷云eye收视数据猎场 编辑:程序博客网 时间:2024/06/07 07:42

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 1.7.0

该版本主要改进内容包括:

 

  • reactor线程与writer线程合并
  • 对send优化,加入out_buffer机制
  • 增加AIO异步读写文件的API
  • 增加DNS异步查询函数
  • swoole_client在php-fpm或apache mod_php下支持长连接
  • 增加非Server模式下的异步定时器支持
  • 定时器优化
  • 增加sendfile支持
  • onReceive的data变量使用引用方式,减少一次内存复制
  • 消息队列模式增加定时器的支持
  • 增加signalfd的支持,使信号事件也加入到Reactor
  • 优化对Internet网络的支持,可轻松应对慢速异构网络

Swoole示例

Php代码 
  1. $serv = new swoole_server("127.0.0.1", 9501);  
  2. $serv->on('connect'function ($serv$fd){  
  3.     echo "Client:Connect.\n";  
  4. });  
  5. $serv->on('receive'function ($serv$fd$from_id$data) {  
  6.     $serv->send($fd'Swoole: '.$data);  
  7.     //$serv->close($fd);  
  8. });  
  9. $serv->on('close'function ($serv$fd) {  
  10.     echo "Client: Close.\n";  
  11. });  
  12. $serv->start();  

 

Php代码 
  1. $client = new swoole_client(SWOOLE_SOCK_TCP, SWOOLE_SOCK_ASYNC);  
  2. $client->on("connect"function($cli) {  
  3.     $cli->send("hello world\n");  
  4. });  
  5. $client->on("receive"function($cli$data = ""){  
  6.     echo "Receive: ".$data.PHP_EOL;  
  7. });  
  8. $client->on("error"function($cli){  
  9.     echo "connect fail\n";  
  10. });  
  11. $client->on("close"function($cli){  
  12.     echo "connection close\n";  
  13. });  
  14. $client->connect('127.0.0.1', 9501, 0.5);  
0 0
原创粉丝点击