好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PHP swoole的process模塊創建和使用子進程操作示例

PHP swoole的process模塊創建和使用子進程操作示例

熱門標簽:咸陽電銷 邢臺400電話辦理 濟源百應電銷機器人聯系方式 嘟嘟云外呼系統 南京3D地圖標注 正規電銷機器人系統 重慶外呼電銷系統多少錢 南寧電話外呼系統線路 辦理400電話哪家好點

本文實例講述了PHP swoole的process模塊創建和使用子進程操作。分享給大家供大家參考,具體如下:

swoole中為我們提供了一個進程管理模塊 Process,替換PHP的 pcntl 擴展,方便我們創建進程,管理進程,和進程間的通信。

swoole提供了2種進程間的通信:

1、基于 unix socket 的管道 pipe。

2、基于 sysvmsg 的消息隊列。

我們可以通過 new swoole_process() 快速的創建一個進程,默認會創建一個 SOCK_DGRAM 類型的管道,用于進程間的通信,當然可以設置成其他類型,也可以不創建。

一、通過同步阻塞管道進行進程間通信

?php
$worker_process_nums = 5;
$worker_process = [];
 
for ($i = 0; $i  $worker_process_nums; $i++) {
  //創建子進程
  //默認為每個子進程創建一個管道,如果不想創建設置$pipe_type參數為false
  //注意管道默認是同步阻塞,半雙工,如果讀取不到數據就會阻塞
  $worker = new swoole_process(function (swoole_process $worker) {
    //注意,如果主進程中不寫數據write(),那么子進程這里read()就會阻塞
    $task = json_decode($worker->read(), true);
 
    //進行計算任務
    $tmp = 0;
    for ($i = $task['start']; $i  $task['end']; $i++) {
      $tmp += $i;
    }
 
    echo '子進程 PID : ', $worker->pid, ' 計算 ', $task['start'], ' - ', $task['end'], ' 結果 : ', $tmp, PHP_EOL;
    //往管道中寫入計算的結果
    $worker->write($tmp);
    //子進程退出
    $worker->exit();
  });
 
  //保存子進程
  $worker_process[$i] = $worker;
 
  //啟動子進程
  $worker->start();
}
 
//往每個子進程管道中投遞任務
for ($i = 0; $i  $worker_process_nums; $i++) {
  $worker_process[$i]->write(json_encode([
    'start' => mt_rand(1, 10),
    'end' => mt_rand(50, 100),
  ]));
}
 
//父進程監聽子進程退出信號,回收子進程,防止出現僵尸進程
swoole_process::signal(SIGCHLD, function ($sig) {
  //必須為false,非阻塞模式
  while ($ret = swoole_process::wait(false)) {
    echo "子進程 PID : {$ret['pid']} 退出\n";
  }
});

二、通過 swoole_event_add 將管道設為異步,來進行通信

?php
$worker_process_nums = 5;
$worker_process = [];
 
for ($i = 0; $i  $worker_process_nums; $i++) {
  $worker = new swoole_process(function ($worker) {
    //在子進程中給管道添加事件監聽
    //底層會自動將該管道設置為非阻塞模式
    //參數二,是可讀事件回調函數,表示管道可以讀了
    swoole_event_add($worker->pipe, function ($pipe) use ($worker) {
      $task = json_decode($worker->read(), true);
 
      $tmp = 0;
      for ($i = $task['start']; $i  $task['end']; $i++) {
        $tmp += $i;
      }
      echo "子進程 : {$worker->pid} 計算 {$task['start']} - {$task['end']} \n";
      //子進程把計算的結果,寫入管道
      $worker->write($tmp);
      //注意,swoole_event_add與swoole_event_del要成對使用
      swoole_event_del($worker->pipe);
      //退出子進程
      $worker->exit();
    });
  });
 
  $worker_process[$i] = $worker;
 
  //啟動子進程
  $worker->start();
}
 
for ($i = 0; $i  $worker_process_nums; $i++) {
  $worker = $worker_process[$i];
 
  $worker->write(json_encode([
    'start' => mt_rand(1, 10),
    'end' => mt_rand(50, 100),
  ]));
 
  //主進程中,監聽子進程管道事件
  swoole_event_add($worker->pipe, function ($pipe) use ($worker) {
    $result = $worker->read();
    echo "子進程 : {$worker->pid} 計算結果 {$result} \n";
    swoole_event_del($worker->pipe);
  });
}
 
//父進程監聽子進程退出信號,回收子進程,防止出現僵尸進程
swoole_process::signal(SIGCHLD, function ($sig) {
  //必須為false,非阻塞模式
  while ($ret = swoole_process::wait(false)) {
    echo "子進程 PID : {$ret['pid']} 退出\n";
  }
});

三、使用消息隊列來完成進程間通信

?php
$worker_process_nums = 5;
$worker_process = [];
 
for ($i = 0; $i  $worker_process_nums; $i++) {
  //注意,這里將參數$pipe_type設為false,表示不創建管道
  $worker = new swoole_process(function ($worker) {
    $task = json_decode($worker->pop(), true);
 
    $tmp = 0;
    for ($i = $task['start']; $i  $task['end']; $i++) {
      $tmp += $i;
    }
    echo "子進程 : {$worker->pid} 計算 {$task['start']} - {$task['end']} \n";
    $worker->push($tmp);
    $worker->exit();
  }, false, false);
 
  //使用消息隊列,作為進程間的通信
  //注意,消息隊列是共享的
  $worker->useQueue();
 
  $worker_process[$i] = $worker;
 
  //啟動子進程
  $worker->start();
}
 
for ($i = 0; $i  $worker_process_nums; $i++) {
  //只需用一個子進程發送消息即可,因為消息隊列是共享的
  $worker_process[0]->push(json_encode([
    'start' => mt_rand(1, 10),
    'end' => mt_rand(50, 100),
  ]));
}
 
//注意,這里要暫停,防止加入隊列的任務,立刻被主進程讀出來。
sleep(1);
 
for ($i = 0; $i  $worker_process_nums; $i++) {
  $result = $worker_process[0]->pop();
  echo "計算結果 : {$result} \n";
}
 
//父進程監聽子進程退出信號,回收子進程,防止出現僵尸進程
swoole_process::signal(SIGCHLD, function ($sig) {
  //必須為false,非阻塞模式
  while ($ret = swoole_process::wait(false)) {
    echo "子進程 PID : {$ret['pid']} 退出\n";
  }
});

四、進程可以通過 signal 監聽信號,和 alarm 設置定時器。

我們可以在父進程上設置監聽信號,當子進程退出時,重新掛起子進程。

也可以設置定時器,通過 swoole_process::kill($pid, 0); 定時檢測進程是否存活。

?php
//每隔1秒觸發SIGALAM信號
//注意,alarm不能和Timer同時使用
swoole_process::alarm(1000 * 1000, 0);
 
swoole_process::signal(SIGALRM, function ($signo) {
  static $cnt = 0;
  $cnt++;
  echo "時鐘定時信號\n";
 
  if ($cnt > 10) {
    //清除定時器
    swoole_process::alarm(-1);
  }
});
 
swoole_process::signal(SIGINT, function ($signo) {
  echo "我被ctrl+c了\n";
 
  //退出主進程,不然將一直無法正常退出
  exit(0);
});

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP網絡編程技巧總結》、《php socket用法總結》、《php面向對象程序設計入門教程》、《PHP數據結構與算法教程》及《php程序設計算法總結》

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

您可能感興趣的文章:
  • 淺談swoole的作用與原理
  • 淺談Swoole并發編程的魅力
  • 詳解PHP Swoole長連接常見問題
  • 詳解PHP Swoole與TCP三次握手
  • Swoole擴展的6種模式深入詳解
  • php中Swoole的熱更新實現代碼實例
  • swoole鎖的機制代碼實例講解
  • Swoole源碼中如何查詢Websocket的連接問題詳解
  • 詳解Swoole跟傳統的web開發的區別

標簽:武漢 平頂山 南通 隴南 通遼 唐山 黃山 河南

巨人網絡通訊聲明:本文標題《PHP swoole的process模塊創建和使用子進程操作示例》,本文關鍵詞  PHP,swoole,的,process,模塊,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP swoole的process模塊創建和使用子進程操作示例》相關的同類信息!
  • 本頁收集關于PHP swoole的process模塊創建和使用子進程操作示例的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 金瓶悔扬思敏完整版在线| 日本《凄辱护士》| 久久久久久精品一级毛片蜜月| 《好好疼爱里面》动漫 | 肉蒲团在线观看| 国产剧在线观看免费全集电视剧| 男女生靠逼视频| 夜夜爽夜夜| 二人の巨乳妻美和と茜?演员| 国语对白做爰又粗又大| 亚洲人成网站在线观看妞妞网| 欧美高清HD19???| ?国产精品樱花嫩草影院| 男人j桶进女人免费视频| 精品久久久久综合桃花网| 被你的上司侵犯了电影| 国产精品一国产精品k频道56| 国产调教网站| 催眠小说邻居系列| 五月丁香欧美综合亚洲AV| 爱情岛论坛国产福利视频| 综合五月天堂| 身为人母完整电影| 与老头共享娇妻绿帽小说| 亲子乱Av一区区三区40岁| 两性性爽视频片| 啦啦啦免费高清在线观看视频播放| 五十六十丰满老熟妇HD| 无遮挡男女| 国产成人亚洲精品影院| 4虎最新地址| 噼里啪啦免费观看高清完整版| 国产精品成人a?v久久A片小| 直接看黄的网站| 绝代无双| 国产精品久久久久精品香港乳瀑瀑| 看全色黄大色大片60岁| 可以免费看黄色的网站| 国产无线卡一卡二区别在哪| 他一边曰一边吃我奶头视频| 国产毛片久久国产|