欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Swoole 1.10.0新版本发布,增加了多项新特性

程序员文章站 2022-11-16 08:15:34
前言 swoole 可以广泛应用于互联网、移动通信、企业软件、云计算、网络游戏、物联网(iot)、车联网、智能家居等领域。使用 php + swoole 作为网络通信框架...

前言

swoole 可以广泛应用于互联网、移动通信、企业软件、云计算、网络游戏、物联网(iot)、车联网、智能家居等领域。使用 php + swoole 作为网络通信框架,可以使企业 it 研发团队的效率大大提升,更加专注于开发创新产品。最近,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\r\n\r\n");
});
$client->on("receive", function(swoole_client $cli, $data){
 echo "receive: $data";
 $cli->send(str_repeat('a', 100)."\n");
 sleep(1);
});
$client->on("error", function(swoole_client $cli){
 echo "error\n";
});
$client->on("close", function(swoole_client $cli){
 echo "connection close\n";
});
//底层会自动进行异步域名解析
$client->connect('www.baidu.com', 9501);

慢请求日志

新版本增加了追踪慢请求功能,可记录慢请求的 php 函数调用栈。

function test()
{
 test_sleep();
}
function test_sleep()
{
 echo "sleep 5\n";
 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) . "\n";
});
$serv->start();
  • reactor 和 worker 之间通信,使用 dispatch_mode = 7 来开启
  • worker 和 task 之间通信,使用 task_ipc_mode = 4 来开启

增加 event::cycle 函数

用户代码可自定义一个 eventloop 的钩子函数,此函数会在每一轮事件循环结束时调用。方便使用 generator + yield 或 promise 类 swoole 框架实现自己的调度器。

swoole\timer::tick(2000, function ($id) {
 var_dump($id);
});
swoole\event::cycle(function () {
 echo "hello [1]\n";
 swoole\event::cycle(function () {
 echo "hello [2]\n";
 swoole\event::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:

开源中国:

pecl:

本地下载:

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。