Swoole實(shí)現(xiàn)異步投遞task任務(wù)案例詳解
本文實(shí)例講述了Swoole實(shí)現(xiàn)異步投遞task任務(wù)案例。分享給大家供大家參考,具體如下:
【使用場(chǎng)景】
Swolle的task模塊可以用來(lái)做一些異步的慢速任務(wù)、耗時(shí)場(chǎng)景。如webim中發(fā)廣播,發(fā)送郵件等,把這些任務(wù)丟給task進(jìn)程之后,worker進(jìn)程可以繼續(xù)處理新的數(shù)據(jù)請(qǐng)求,任務(wù)完成后會(huì)異步通知worker進(jìn)程告訴它此任務(wù)已經(jīng)完成。此外利用task還可以實(shí)現(xiàn)PHP的數(shù)據(jù)庫(kù)連接池,異步隊(duì)列等。
【使用須知】
必須設(shè)置Task進(jìn)程數(shù): task_worker_num
投遞一個(gè)異步任務(wù)到task_worker池中:Server->task
必須注冊(cè)onTask、onFinish2個(gè)事件回調(diào)函數(shù)。
【示例】
以創(chuàng)建一個(gè)WebSocket服務(wù)異步投遞任務(wù)為例:
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進(jìn)程數(shù) 'task_worker_num' => 2, //task進(jìn)程數(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進(jìn)程異步投遞任務(wù)到task_worker進(jìn)程中 $data = [ 'fd' => $frame->fd, ]; $ws->task($data); //服務(wù)器返回 echo "服務(wù)器發(fā)送消息:666"; } //完成異步任務(wù)回調(diào) public function onTask($serv, $task_id, $worker_id, $data) { var_dump($data); //模擬慢速任務(wù) sleep(5); //返回字符串給worker進(jìn)程——>觸發(fā)onFinish return "success"; } //完成任務(wù)投遞回調(diào) public function onFinish($serv, $task_id, $data) { //task_worker進(jìn)程將任務(wù)處理結(jié)果發(fā)送給worker進(jìn)程 echo "完成任務(wù){(diào)$task_id}投遞 處理結(jié)果:{$data}"; } //關(guān)閉連接回調(diào) public function onClose($ws, $fd) { echo "{$fd}關(guān)閉了連接"; } } $obj = new Ws();
前端頁(yè)面js監(jiān)聽(tīng):
<!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服務(wù)器 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>
開(kāi)啟WebSocket服務(wù):
php ws_server.php
前后刷新了兩次頁(yè)面,WebSocket服務(wù)器監(jiān)聽(tīng)結(jié)果:
(服務(wù)器會(huì)先返回消息給客戶端,然后再執(zhí)行投遞任務(wù))
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP擴(kuò)展開(kāi)發(fā)教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php正則表達(dá)式用法總結(jié)》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- PHP swoole中使用task進(jìn)程異步的處理耗時(shí)任務(wù)應(yīng)用案例分析
- PHP Swoole異步讀取、寫入文件操作示例
- PHP Swoole異步Redis客戶端實(shí)現(xiàn)方法示例
- PHP Swoole異步MySQL客戶端實(shí)現(xiàn)方法示例
- php基于 swoole 實(shí)現(xiàn)的異步處理任務(wù)功能示例
- PHP swoole和redis異步任務(wù)實(shí)現(xiàn)方法分析
- PHP擴(kuò)展Swoole實(shí)現(xiàn)實(shí)時(shí)異步任務(wù)隊(duì)列示例
- 詳解thinkphp5+swoole實(shí)現(xiàn)異步郵件群發(fā)(SMTP方式)
- php異步多線程swoole用法實(shí)例
- 如何用RabbitMQ和Swoole實(shí)現(xiàn)一個(gè)異步任務(wù)系統(tǒng)
相關(guān)文章
利用客戶端緩存對(duì)網(wǎng)站進(jìn)行優(yōu)化的原理分析
你的網(wǎng)站在并發(fā)訪問(wèn)很大并且無(wú)法承受壓力的情況下,你會(huì)選擇如何優(yōu)化?2008-09-09php下實(shí)現(xiàn)一個(gè)阿拉伯?dāng)?shù)字轉(zhuǎn)中文數(shù)字的函數(shù)
最近因需要,寫了個(gè)“阿拉伯?dāng)?shù)字轉(zhuǎn)中文數(shù)字的函數(shù)”。搜索了精華區(qū)只見(jiàn)到一個(gè)類似的。 感覺(jué)到我的算法不錯(cuò),所以貼出來(lái)共享一下2008-07-07Laravel?Eloquent取上一條和下一條數(shù)據(jù)的id實(shí)現(xiàn)講解
這篇文章主要為大家介紹了Laravel?Eloquent取上一條和下一條數(shù)據(jù)的id實(shí)現(xiàn)講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06PHP排序算法之快速排序(Quick Sort)及其優(yōu)化算法詳解
這篇文章主要介紹了PHP排序算法之快速排序(Quick Sort)及其優(yōu)化算法,結(jié)合實(shí)例形式分析了php快速排序的原理、實(shí)現(xiàn)方法,并分析了各種優(yōu)化技巧與操作注意事項(xiàng),需要的朋友可以參考下2018-04-04php array_walk array_map array_filter區(qū)別案例詳解
這篇文章主要介紹了php array_walk array_map array_filter區(qū)別案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09