本文實例講述了Swoole實現(xiàn)異步投遞task任務案例。分享給大家供大家參考,具體如下:
【使用場景】
Swolle的task模塊可以用來做一些異步的慢速任務、耗時場景。如webim中發(fā)廣播,發(fā)送郵件等,把這些任務丟給task進程之后,worker進程可以繼續(xù)處理新的數(shù)據(jù)請求,任務完成后會異步通知worker進程告訴它此任務已經(jīng)完成。此外利用task還可以實現(xiàn)PHP的數(shù)據(jù)庫連接池,異步隊列等。
【使用須知】
必須設置Task進程數(shù): task_worker_num
投遞一個異步任務到task_worker池中:Server->task
必須注冊onTask、onFinish2個事件回調(diào)函數(shù)。
【示例】
以創(chuàng)建一個WebSocket服務異步投遞任務為例:
ws_server.php:
?php
class Ws {
public $ws = null;
public function __construct() {
$this->ws = new swoole_websocket_server("0.0.0.0", 9501);
$this->ws->set([
'worker_num' => 2, //worker進程數(shù)
'task_worker_num' => 2, //task進程數(shù)
]);
$this->ws->on("open", [$this, 'onOpen']);
$this->ws->on("message", [$this, 'onMessage']);
$this->ws->on("task", [$this, 'onTask']);
$this->ws->on("finish", [$this, 'onFinish']);
$this->ws->on("close", [$this, 'onClose']);
$this->ws->start();
}
//建立連接回調(diào)
public function onOpen($ws, $request) {
echo "{$request->fd}建立了連接";
}
//接受消息回調(diào)
public function onMessage($ws, $frame) {
//worker進程異步投遞任務到task_worker進程中
$data = [
'fd' => $frame->fd,
];
$ws->task($data);
//服務器返回
echo "服務器發(fā)送消息:666";
}
//完成異步任務回調(diào)
public function onTask($serv, $task_id, $worker_id, $data) {
var_dump($data);
//模擬慢速任務
sleep(5);
//返回字符串給worker進程——>觸發(fā)onFinish
return "success";
}
//完成任務投遞回調(diào)
public function onFinish($serv, $task_id, $data) {
//task_worker進程將任務處理結果發(fā)送給worker進程
echo "完成任務{(diào)$task_id}投遞 處理結果:{$data}";
}
//關閉連接回調(diào)
public function onClose($ws, $fd) {
echo "{$fd}關閉了連接";
}
}
$obj = new Ws();
前端頁面js監(jiān)聽:
!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
html xmlns="http://www.w3.org/1999/xhtml">
head>
title>WebSocket/title>
/head>
body>
/body>
script type="text/javascript">
var websocket = new WebSocket('ws://127.0.0.1:9501');
websocket.onopen = function (evt) { onOpen(evt) };
websocket.onclose = function (evt) { onClose(evt) };
websocket.onmessage = function (evt) { onMessage(evt) };
websocket.onerror = function (evt) { onError(evt) };
function onOpen(evt) {
console.log("Connected to WebSocket server.");
//*發(fā)送消息到websocket服務器
websocket.send('666');
}
function onClose(evt) {
console.log("Disconnected");
}
function onMessage(evt) {
console.log('Retrieved data from server: ' + evt.data);
}
function onError(evt) {
console.log('Error occured: ' + evt.data);
}
/script>
/html>
開啟WebSocket服務:
前后刷新了兩次頁面,WebSocket服務器監(jiān)聽結果:
![](/d/20211017/6bbde09600cf79ac5c2901637b7ee5b3.gif)
![](/d/20211017/e2097c28f33dbfc24a4430260bbf4e19.gif)
(服務器會先返回消息給客戶端,然后再執(zhí)行投遞任務)
更多關于PHP相關內(nèi)容感興趣的讀者可查看本站專題:《PHP擴展開發(fā)教程》、《php面向對象程序設計入門教程》、《PHP數(shù)學運算技巧總結》、《PHP數(shù)組(Array)操作技巧大全》、《PHP數(shù)據(jù)結構與算法教程》、《php程序設計算法總結》、《php正則表達式用法總結》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:- PHP swoole中使用task進程異步的處理耗時任務應用案例分析
- PHP Swoole異步讀取、寫入文件操作示例
- PHP Swoole異步Redis客戶端實現(xiàn)方法示例
- PHP Swoole異步MySQL客戶端實現(xiàn)方法示例
- php基于 swoole 實現(xiàn)的異步處理任務功能示例
- PHP swoole和redis異步任務實現(xiàn)方法分析
- PHP擴展Swoole實現(xiàn)實時異步任務隊列示例
- 詳解thinkphp5+swoole實現(xiàn)異步郵件群發(fā)(SMTP方式)
- php異步多線程swoole用法實例
- 如何用RabbitMQ和Swoole實現(xiàn)一個異步任務系統(tǒng)