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 來開啟
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); }); });
以上是Swoole 1.10.0新版本詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!