主頁 > 知識庫 > Swoole實現(xiàn)異步投遞task任務(wù)案例詳解

Swoole實現(xiàn)異步投遞task任務(wù)案例詳解

熱門標簽:阿里云400電話申請加工單 抖音有個地圖標注是什么意思 九江外呼系統(tǒng) 智能電話機器人排名前十名南京 保定crm外呼系統(tǒng)運營商 西區(qū)企業(yè)怎么做地圖標注入駐 地下城堡2圖九地圖標注 海南人工外呼系統(tǒng)有效果嗎 七魚外呼系統(tǒng)停用嗎

本文實例講述了Swoole實現(xiàn)異步投遞task任務(wù)案例。分享給大家供大家參考,具體如下:

【使用場景】

      Swolle的task模塊可以用來做一些異步的慢速任務(wù)、耗時場景。如webim中發(fā)廣播,發(fā)送郵件等,把這些任務(wù)丟給task進程之后,worker進程可以繼續(xù)處理新的數(shù)據(jù)請求,任務(wù)完成后會異步通知worker進程告訴它此任務(wù)已經(jīng)完成。此外利用task還可以實現(xiàn)PHP的數(shù)據(jù)庫連接池,異步隊列等。

【使用須知】

      必須設(shè)置Task進程數(shù): task_worker_num

      投遞一個異步任務(wù)到task_worker池中:Server->task

      必須注冊onTask、onFinish2個事件回調(diào)函數(shù)。

 【示例】

以創(chuàng)建一個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進程數(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進程異步投遞任務(wù)到task_worker進程中
    $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進程——>觸發(fā)onFinish
    return "success";
  }

  //完成任務(wù)投遞回調(diào)
  public function onFinish($serv, $task_id, $data) {
    //task_worker進程將任務(wù)處理結(jié)果發(fā)送給worker進程
    echo "完成任務(wù){(diào)$task_id}投遞 處理結(jié)果:{$data}";
  }

  //關(guān)閉連接回調(diào)
  public function onClose($ws, $fd) {
    echo "{$fd}關(guān)閉了連接";
  }
}

$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服務(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>

開啟WebSocket服務(wù):

php ws_server.php

前后刷新了兩次頁面,WebSocket服務(wù)器監(jiān)聽結(jié)果:

(服務(wù)器會先返回消息給客戶端,然后再執(zhí)行投遞任務(wù))

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP擴展開發(fā)教程》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《PHP數(shù)學運算技巧總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計算法總結(jié)》、《php正則表達式用法總結(jié)》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對大家PHP程序設(shè)計有所幫助。

您可能感興趣的文章:
  • PHP swoole中使用task進程異步的處理耗時任務(wù)應(yīng)用案例分析
  • PHP Swoole異步讀取、寫入文件操作示例
  • PHP Swoole異步Redis客戶端實現(xiàn)方法示例
  • PHP Swoole異步MySQL客戶端實現(xiàn)方法示例
  • php基于 swoole 實現(xiàn)的異步處理任務(wù)功能示例
  • PHP swoole和redis異步任務(wù)實現(xiàn)方法分析
  • PHP擴展Swoole實現(xiàn)實時異步任務(wù)隊列示例
  • 詳解thinkphp5+swoole實現(xiàn)異步郵件群發(fā)(SMTP方式)
  • php異步多線程swoole用法實例
  • 如何用RabbitMQ和Swoole實現(xiàn)一個異步任務(wù)系統(tǒng)

標簽:遼陽 涼山 昭通 韶關(guān) 甘肅 梅河口 十堰 九江

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Swoole實現(xiàn)異步投遞task任務(wù)案例詳解》,本文關(guān)鍵詞  Swoole,實現(xiàn),異步,投遞,task,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Swoole實現(xiàn)異步投遞task任務(wù)案例詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于Swoole實現(xiàn)異步投遞task任務(wù)案例詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章