摘要:的异步并行高性能网络通信引擎已发布版本。此版本增加了多项新特性。复杂的线上项目使用模式,请求分配调度的效率更高。方便使用或类框架实现自己的调度器。
PHP的异步、并行、高性能网络通信引擎 Swoole 已发布 1.10.0 版本。此版本增加了多项新特性。
自动 DNS 解析新版本的异步客户端不再需要使用 swoole_async_dns_lookup 解析域名了,底层实现了自动域名解析。Client 在执行 connect 方法时可直接传入域名。
$client = new swoole_client(SWOOLE_SOCK_TCP, SWOOLE_SOCK_ASYNC); $client->on("connect", function(swoole_client $cli) { $cli->send("GET / HTTP/1.1 "); }); $client->on("receive", function(swoole_client $cli, $data){ echo "Receive: $data"; $cli->send(str_repeat("A", 100)." "); sleep(1); }); $client->on("error", function(swoole_client $cli){ echo "error "; }); $client->on("close", function(swoole_client $cli){ echo "Connection close "; }); //底层会自动进行异步域名解析 $client->connect("www.baidu.com", 9501);慢请求日志
新版本增加了追踪慢请求功能,可记录慢请求的 PHP 函数调用栈。
function test() { test_sleep(); } function test_sleep() { echo "sleep 5 "; sleep(5); } $server = new swoole_server("127.0.0.1", 9501); $server->set([ "worker_num" => 1, "task_worker_num" => 1, "trace_event_worker" => true, "request_slowlog_timeout" => 1, "request_slowlog_file" => "/tmp/trace.log", ]); $server->on("Receive", function($serv, $fd, $reactor_id, $data) { test(); $serv->send($fd, "Swoole: $data"); }); $server->start();
处理慢请求后,/tmp/trace.log日志中将打印一行错误信息:
[08-Jan-2018 15:21:57] [worker#0] pid 26905 [0x00007f60cda22340] sleep() /home/htf/workspace/swoole/examples/server/trace.php:10 [0x00007f60cda222e0] test_sleep() /home/htf/workspace/swoole/examples/server/trace.php:4 [0x00007f60cda22280] test() /home/htf/workspace/swoole/examples/server/trace.php:28 [0x00007f60cda22190] {closure}() /home/htf/workspace/swoole/examples/server/trace.php:42 [0x00007f60cda22140] start() /home/htf/workspace/swoole/examples/server/trace.php:42新增 STREAM 模块
新增的 stream 模块使得 Reactor、Worker、Task 进程之间的通信方式更灵活,最大程度地解耦。复杂的线上项目使用 stream 模式,请求分配调度的效率更高。
$serv = new swoole_server("127.0.0.1", 9501); $serv->set(array( "dispatch_mode" => 7, "worker_num" => 2, )); $serv->on("receive", function (swoole_server $serv, $fd, $threadId, $data) { var_dump($data); echo "#{$serv->worker_id}>> received length=" . strlen($data) . " "; }); $serv->start();
Reactor 和 Worker 之间通信,使用 dispatch_mode = 7 来开启
Worker 和 Task 之间通信,使用 task_ipc_mode = 4 来开启
增加 Event::cycle 函数用户代码可自定义一个 EventLoop 的钩子函数,此函数会在每一轮事件循环结束时调用。方便使用 Generator + Yield 或 Promise 类 Swoole 框架实现自己的调度器。
SwooleTimer::tick(2000, function ($id) { var_dump($id); }); SwooleEvent::cycle(function () { echo "hello [1] "; SwooleEvent::cycle(function () { echo "hello [2] "; SwooleEvent::cycle(null); }); });其他更新内容
更新Table::incr和Table::decr支持有符号整型
兼容PHP-7.2版本
修复Event::del函数无法移除标准输入句柄的问题
修复Task进程内定时器间隔小于Client接收超时时间,引起Client::recv死锁的问题
增加ssl_host_name配置项,用于验证SSL/TLS主机合法性
使用dispatch_mode = 3时,当所有Worker为忙的状态时打印一条错误日志
增加端口迭代器,可遍历某个监听端口的所有连接
修复Table在非x86平台存在的内存对齐问题
修复BASE模式下max_request配置无效的问题
修复WebSocket服务器在某些客户端ping帧带有mask数据时回包错误的问题
修复HttpClient使用HEAD方法响应内容携带Content-Length导致卡死的问题
增加MySQL异步客户端对JSON格式的支持
下载地址GITHUB:https://github.com/swoole/swo...
开源中国:https://gitee.com/swoole/swoo...
PECL:https://pecl.php.net/package/...
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/26294.html
摘要:修复添加超过万个以上定时器时发生崩溃的问题增加模块,下高性能序列化库修复监听端口设置无效的问题等。线程来处理网络事件轮询,读取数据。当的三次握手成功了以后,由这个线程将连接成功的消息告诉进程,再由进程转交给进程。此时进程触发事件。 本文示例代码详见:https://github.com/52fhy/swoo...。 简介 Swoole是一个PHP扩展,提供了PHP语言的异步多线程服务器...
摘要:年开发并发布框架现已停止维护。经过一年实战,年月日,一周年之际正式发布版本。宇润部分开源项目我已通过码云平台,向项目力所能及地捐款,聊表心意。所以,目前主打的还是单体应用开发。协议的开发,也是带来的一大优势。 imi 介绍 showImg(https://segmentfault.com/img/bVbuab9?w=291&h=187); imi 是基于 PHP 协程应用开发框架,它支...
摘要:开发负责人创建分支,编写单元测试脚本,编写代码,实现提案中的所有内容,最终发起交叉评审,检查代码,提出改进意见,反馈给开发负责人,继续完善细节。 Swoole开源项目从2012年开始发布第一个版本,到现在已经有近7年的历史。在这七年的时间里: 提交了8821次代码变更 发布了287个版本 收到并解决1161次issue反馈 合并了603次pull request 共有100位开发者...
摘要:项新特性个中等级别以上的修复篇文档更新云帮社区版迎来年月更新档。研发团队在这一个月中新增了项新特性,修复了个中等级别以上的,并更新了篇维护文档。本月版本发布支持支持,协议的性能分析,后续还会添加等协议的支持。 13 项新特性、18 个中等级别以上的bug修复、12篇文档更新、云帮社区版 迎来2016年11月更新档。 Cloudbang(云帮) 云帮是好雨科技研发的一款基于容器技术的应用...
阅读 3451·2023-04-25 18:52
阅读 2461·2021-11-22 15:31
阅读 1198·2021-10-22 09:54
阅读 2976·2021-09-29 09:42
阅读 565·2021-09-26 09:55
阅读 883·2021-09-13 10:28
阅读 1063·2019-08-30 15:56
阅读 2082·2019-08-30 15:55