Swoole在PHP-fpm/apache中如何使用task功能?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
創(chuàng)新互聯(lián)建站是一家專業(yè)提供南潯企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、成都h5網(wǎng)站建設(shè)、小程序制作等業(yè)務(wù)。10年已為南潯眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進(jìn)行中。
● 新建 redisServer.php
● 代碼如下
set(array( 'task_worker_num' => 32, 'worker_num' => 1, 'task_enable_coroutine' => true, 'heartbeat_check_interval' => 5, 'heartbeat_idle_time' => 10, )); $server->setHandler('LPUSH', function ($fd, $data) use ($server) { $taskId = $server->task($data); if ($taskId === false) { $server->send($fd, Server::format(Server::ERROR)); } else { $server->send($fd, Server::format(Server::INT, $taskId)); } }); $server->on('Finish', function($serv, $taskID, $data) { $stats = $serv->stats(); if ($stats['tasking_num'] > 10) { //tasking_num 當(dāng)前正在排隊(duì)的任務(wù)數(shù) echo "剩余任務(wù)信息:" . json_encode($serv->stats()) . "\n"; } }); $server->on('Task', function ($serv, $data) { go(function () { usleep(50000); }); var_dump($data); }); $server->start();
task 里面 usleep (50000); 模擬任務(wù)執(zhí)行時(shí)間
● 新建 Queue.php
● 代碼如下
connect('127.0.0.1', 9501); $x=1; while($x <= 1000) { $redis->lpush("myqueue", json_encode(array("hello".$x, "swoole"))); $x++; }
模擬 1000 的任務(wù)投遞
經(jīng)測(cè)試,1 秒處理完畢
可以根據(jù) Task 任務(wù)執(zhí)行的速度調(diào)節(jié) task_worker_num 控制啟動(dòng)的進(jìn)程數(shù)量
● 這些進(jìn)程是由 swoole 底層負(fù)責(zé)管理的,在發(fā)生致命錯(cuò)誤或進(jìn)程退出后底層會(huì)重新創(chuàng)建新的任務(wù)進(jìn)程
task_worker_num
● 最大值不得超過(guò) SWOOLE_CPU_NUM * 1000
● 單個(gè) task 的處理耗時(shí),如 100ms,那一個(gè)進(jìn)程 1 秒就可以處理 1/0.1=10 個(gè) task
● task 投遞的速度,如每秒產(chǎn)生 2000 個(gè) task
● 2000/10=200,需要設(shè)置 task_worker_num => 200,啟用 200 個(gè) task 進(jìn)程
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。