Swoole 快速起步:Task 任務機制的使用

Task任務機制實際是 將耗時進程投遞到異步調用事件Task中處理,從而不阻塞主進程

 Swoole 快速起步:創建 WebSocket 服務器(聊天室)爲例,在 WebSocket 服務器監聽到新消息相應時,需要一些耗時的操作之後纔將數據 send 給客戶端,如果不使用Task任務機制時:

// 監聽 WebSocket 消息事件
$server->on('message', function ($server, $frame) {
    // 開始流程
	echo date("Y-m-d H:i:s") . ":get something\n";
    
    // 耗時的任務開始
	sleep(5);
	echo date("Y-m-d H:i:s") . ":handle something\n";
    // 耗時的任務結束

    foreach ($server->connections as $k => $v) {
        $server->push($v, "會員".$frame->fd.":".$frame->data);
    }
    // 流程完成
    echo date("Y-m-d H:i:s") . ":finish it\n";
});

結果如下:

可見,在開始流程(get something)到 流程完成(finish it)一共耗時 5 秒,原因就在於 那個耗時的任務 sleep(5) !

如果將耗時任務投放到 Task 中做處理:

// 配置
$server->set([
    "worker_num" => 2,
    "task_worker_num" => 2
]);

/* ... */

// 監聽 WebSocket 消息事件
$server->on('message', function ($server, $frame) {
    // 開始流程
    echo date("Y-m-d H:i:s") . ":get something\n";

    // 耗時的任務開始
    $data = "task go!!!";
    $server->task($data);
    // 耗時的任務結束

    foreach ($server->connections as $k => $v) {
        $server->push($v, "會員" . $frame->fd . ":" . $frame->data);
    }
    // 流程完成
    echo date("Y-m-d H:i:s") . ":finish it\n";
});

$server->on("Task", function ($server, $taskId, $workerId, $data) {
    var_dump($data); // $data 來源 $server->task($data); 參數
    sleep(5);
    echo date("Y-m-d H:i:s") . ":handle something\n";
    return "task ok!!!";
});

$server->on("Finish", function ($server, $taskId, $data) {
    var_dump($data);  // $data 來源 onTask($data) return 結果
});

結果:

可見,在開始流程(get something) 到 流程完成(finish it)幾乎不消耗時間!因爲那耗時 5 秒的任務投放在 Task 中異步處理!

發現很多所謂的 高性能 都是將進程投遞到其它進程 異步處理,然後實現監聽處理結果!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章