真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎么在swoole中使用task進(jìn)程來(lái)處理耗時(shí)任務(wù)-創(chuàng)新互聯(lián)

這篇文章主要介紹了怎么在swoole中使用task進(jìn)程來(lái)處理耗時(shí)任務(wù),具有一定借鑒價(jià)值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

超過(guò)10多年行業(yè)經(jīng)驗(yàn),技術(shù)領(lǐng)先,服務(wù)至上的經(jīng)營(yíng)模式,全靠網(wǎng)絡(luò)和口碑獲得客戶(hù),為自己降低成本,也就是為客戶(hù)降低成本。到目前業(yè)務(wù)范圍包括了:成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè),成都網(wǎng)站推廣,成都網(wǎng)站優(yōu)化,整體網(wǎng)絡(luò)托管,微信平臺(tái)小程序開(kāi)發(fā),微信開(kāi)發(fā),app軟件開(kāi)發(fā)公司,同時(shí)也可以讓客戶(hù)的網(wǎng)站和網(wǎng)絡(luò)營(yíng)銷(xiāo)和我們一樣獲得訂單和生意!

如何在swoole中使用task進(jìn)程來(lái)處理耗時(shí)任務(wù)?

我們知道,swoole中有兩大進(jìn)程,分別是master主進(jìn)程和manager管理進(jìn)程。

其中 master 主進(jìn)程中會(huì)有一個(gè)主 reactor 線程和多個(gè) reactor 線程,主要的作用就是用來(lái)維護(hù)TCP連接,處理網(wǎng)絡(luò)IO,收發(fā)數(shù)據(jù)。

而 manager 管理進(jìn)程,作用則是 fork 和管理 worker 和 task 進(jìn)程。

worker 進(jìn)程的作用是接收 reactor 線程傳遞的數(shù)據(jù),并處理數(shù)據(jù),返回處理結(jié)果給 reactor 線程。

task 進(jìn)程的作用是處理一些相對(duì)耗時(shí)的任務(wù),task 與 worker 進(jìn)程是獨(dú)立的,不會(huì)影響 worker 進(jìn)程處理客戶(hù)端的請(qǐng)求。

一、task 進(jìn)程的應(yīng)用場(chǎng)景:

1、相對(duì)耗時(shí)的郵件群發(fā),比如某某活動(dòng),需要給100W用戶(hù)發(fā)送活動(dòng)郵件。

2、推送某些大V的動(dòng)態(tài),比如某大V發(fā)了條新消息,粉絲需要及時(shí)獲取到該動(dòng)態(tài)。

二、worker 與 task 的相互關(guān)系:

1、worker 進(jìn)程中能過(guò)調(diào)用 task() 來(lái)投遞任務(wù),task 進(jìn)程中 通過(guò) onTask 事件來(lái)響應(yīng)投遞來(lái)的任務(wù)。

2、task 進(jìn)程中 通過(guò) 直接返回 或 調(diào)用 finish() 來(lái)告訴 worker 進(jìn)程任務(wù)處理完畢,worker 進(jìn)程中 通過(guò) onFinish 事件響應(yīng)任務(wù)完成。

三、使用 task 的前題:

1、在 Server 中 配置 task_worker_num 數(shù)量。

2、設(shè)置 Server 的 onTask 和 onFinish 事件回調(diào)函數(shù)。

四、簡(jiǎn)單的使用task進(jìn)行累加和的計(jì)算例子

set([
    'worker_num' => 2,
    'task_worker_num' => 16,
]);
 
$server->on('WorkerStart', function ($server, $worker_id) {
    //注意這里,我們通過(guò)taskworker來(lái)判斷是task進(jìn)程還是worker進(jìn)程
    //需要在worker進(jìn)程中調(diào)用task(),不然會(huì)報(bào)出警告
    //這里會(huì)執(zhí)行兩遍,因?yàn)槲覀冊(cè)O(shè)置了worker_num數(shù)為2
    if (!$server->taskworker) {
        echo '投遞任務(wù)開(kāi)始...', PHP_EOL;
        //投遞32個(gè)累加計(jì)算任務(wù)給16個(gè)task進(jìn)程
        for ($ix = 0; $ix < 32; $ix++) {
            //注意這里的投遞是異步的
            $server->task([mt_rand(1, 100), mt_rand(1000, 9999)]);
        }
        echo '投遞任務(wù)結(jié)束...', PHP_EOL;
    }
});
 
//server服務(wù)必須要有onReceive回調(diào)
$server->on('Receive', function ($server, $fd, $reactor_id, $data) {
 
});
 
//注意,task進(jìn)程完全是同步阻塞模式的
$server->on('Task', function ($server, $task_id, $src_worker_id, $data) {
    echo "task {$task_id} 進(jìn)程正在工作...", PHP_EOL;
    $start = $data[0];
    $end = $data[1];
    $total = 0;
    for (; $start <= $end; $start++) {
        $total += $start;
    }
    echo "task {$task_id} 進(jìn)程完成工作...", PHP_EOL;
    return $total;
});
 
$server->on('Finish', function ($server, $task_id, $data) {
    echo "task {$task_id} 進(jìn)程處理完成, 結(jié)果為 {$data}", PHP_EOL;
});
 
$server->start();

注意,我們通過(guò)調(diào)用 task() 往任務(wù)池中投遞任務(wù),swoole 底層會(huì)輪詢(xún)的投遞任務(wù)到各個(gè) task 進(jìn)程。

當(dāng)你投遞任務(wù)的數(shù)量超過(guò) onTask 的處理速度,這會(huì)導(dǎo)致任務(wù)池被塞滿(mǎn),進(jìn)而導(dǎo)致 worker 進(jìn)程發(fā)生阻塞,所以需合理設(shè)置 task_worker_num 數(shù)量和處理速度之間的關(guān)系。

當(dāng)然,我們也可以人為的把任務(wù)投遞到指定的 task 進(jìn)程。task() 函數(shù)的第二個(gè)參數(shù)可以指定要投遞的 task 進(jìn)程ID,ID范圍為 0 到 (task_worker_num - 1)。

五、對(duì)任務(wù)進(jìn)行切分,人為控制投遞到 task 進(jìn)程

set([
    'worker_num' => 1,
    'task_worker_num' => 10,
]);
 
$server->on('WorkerStart', function ($server, $worker_id) {
    //為了方便演示,把worker_num設(shè)置為1,這里只會(huì)執(zhí)行一次
    if (!$server->taskworker) {
        //通過(guò)swoole_table共享內(nèi)存,在不同進(jìn)程中共享數(shù)據(jù)
        $server->result = new swoole_table(10240);
        //用于保存task進(jìn)程完成數(shù)量
        $server->result->column('finish_nums', swoole_table::TYPE_INT);
        //用于保存最終計(jì)算結(jié)果
        $server->result->column('result', swoole_table::TYPE_INT);
        $server->result->create();
        //計(jì)算1000的累加和,并把計(jì)算任務(wù)分配到10個(gè)task進(jìn)程上
        $num = 1000;
        $step = $num / $server->setting['task_worker_num'];
        for ($ix = 0; $ix < $server->setting['task_worker_num']; $ix++) {
            $start = $ix * $step;
            $server->task([$start, $start + $step], $ix);
        }
    }
});
 
$server->on('Receive', function ($server, $fd, $reactor_id, $data) {
 
});
 
//注意,task進(jìn)程完全是同步阻塞模式的
$server->on('Task', function ($server, $task_id, $src_worker_id, $data) {
    echo "task {$task_id} 進(jìn)程正在工作... 計(jì)算 {$data[0]} - {$data[1]} ", PHP_EOL;
    $start = ++$data[0];
    $end = $data[1];
    $total = 0;
    for (; $start <= $end; $start++) {
        $total += $start;
    }
    echo "task {$task_id} 進(jìn)程完成工作...", PHP_EOL;
    return $total;
});
 
$server->on('Finish', function ($server, $task_id, $data) {
    echo "task {$task_id} 進(jìn)程處理完成, 結(jié)果為 {$data}", PHP_EOL;
    $server->result->incr('finish_nums', 'finish_nums');
    $server->result->set('result', ['result' => $data + $server->result->get('result', 'result')]);
 
    if ($server->result->get('finish_nums', 'finish_nums') == $server->setting['task_worker_num']) {
        echo "最終計(jì)算結(jié)果:{$server->result->get('result', 'result')}", PHP_EOL;
    }
});
 
$server->s
tart();

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享怎么在swoole中使用task進(jìn)程來(lái)處理耗時(shí)任務(wù)內(nèi)容對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,遇到問(wèn)題就找創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,詳細(xì)的解決方法等著你來(lái)學(xué)習(xí)!


當(dāng)前文章:怎么在swoole中使用task進(jìn)程來(lái)處理耗時(shí)任務(wù)-創(chuàng)新互聯(lián)
分享URL:http://weahome.cn/article/ijchh.html

其他資訊

在線咨詢(xún)

微信咨詢(xún)

電話咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部