佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > PHP基于swoole多進程操作示例

PHP基于swoole多進程操作示例

熱門標簽:阿里云 電子圍欄 銀行業(yè)務 科大訊飛語音識別系統(tǒng) 團購網(wǎng)站 Mysql連接數(shù)設置 服務器配置 Linux服務器

本文實例講述了PHP基于swoole多進程操作。分享給大家供大家參考,具體如下:

多個任務同時執(zhí)行

將順序執(zhí)行的任務,轉化為并行執(zhí)行(任務在邏輯上可以并行執(zhí)行)
比如,我們要對已知的用戶數(shù)據(jù)進行判斷,是否需要發(fā)送郵件和短信,如果需要發(fā)送則發(fā)送。

不使用多進程時,我們首先判斷是否發(fā)送郵件,如果需要則發(fā)送;然后再判斷是否需要發(fā)送短信,如果需要則發(fā)送。如果發(fā)送郵件耗時2s,發(fā)送短信耗時2s,那么我們完成任務大概需要4s左右的時間。

如果我們使用多線程的話,可以開兩個線程,一個用于處理郵件,一個用于處理短信,則耗時一共需要2s左右,處理時間縮短了一半。

?php
/**
 * Created by PhpStorm.
 * User: zhezhao
 * Date: 2016/10/20
 * Time: 10:37
 */
$info = array(
  "sendmail"=>1,
  "mailto"=>"12345@qq.com",
  "sendsms"=>1,
  "smsto"=>"123456"
);
echo "start:".date("Y-m-d H:i:s").PHP_EOL;
$mail_process = new swoole_process('sendMail',true);
$mail_process->start();
$sms_process = new swoole_process('sendSMS',true);
$sms_process->start();
//主進程輸出子進程范圍內(nèi)容
echo $mail_process->read();
echo PHP_EOL;
echo $sms_process->read();
echo PHP_EOL;
echo "end:".date("Y-m-d H:i:s").PHP_EOL;
//并行函數(shù)
function sendMail(swoole_process $worker){
  global $info;
  if($info['sendmail']==1){
    sleep(2);
    $worker->write("send mail to ".$info['mailto']);
  }
}
function sendSMS(swoole_process $worker){
  global $info;
  if($info['sendmail']==1){
    sleep(2);
    $worker->write("send sms to ".$info['smsto']);
  }
}

大任務劃分成多個小任務

將循環(huán)執(zhí)行的任務,劃分為多個進程執(zhí)行,提高工作效率

假設我們現(xiàn)在有一個通過curl抓取網(wǎng)頁內(nèi)容的需求,需要抓取10個網(wǎng)頁,url地址通過數(shù)組讀取,每個curl耗時2s。如果我們通過for循環(huán)來抓取這10個網(wǎng)頁,需要耗時20s,使用多進程我們可以將任務劃分成5份,分別由5個進程執(zhí)行,每個進程抓取2個url,并發(fā)執(zhí)行,共耗時4s,效率提高5倍。

?php
/**
 * Created by PhpStorm.
 * User: zhezhao
 * Date: 2016/10/20
 * Time: 10:51
 */
$url_arr = array();
for ($i=0;$i10;$i++){
  $url_arr[] = "www.baidu.com?wd=".$i;
}
echo "start:".date("Y-m-d H:i:s").PHP_EOL;
$workers = array();
for ($i=0;$i5;$i++){
  $process = new swoole_process('getContents',true);
  $process->start();
  $process->write($i);
  $workers[] = $process;
}
//主進程數(shù)據(jù)結果
foreach ($workers as $process){
  echo $process->read();
  echo PHP_EOL;
}
echo "end:".date("Y-m-d H:i:s").PHP_EOL;
function getContents(swoole_process $worker){
  $i = $worker->read();
  global $url_arr;
  $res1 = execCurl($url_arr[($i*2)]);
  $res2 = execCurl($url_arr[($i*2+1)]);
  echo $res1.PHP_EOL.$res2;
}
function execCurl($url){
  sleep(2);
  return "handle ".$url." finished";
}

總結

以上兩種情況,本質(zhì)上都是將邏輯上沒有先后關系的任務,用多個進程程并發(fā)執(zhí)行,提高效率。

php機制本身不提供多線程的操作,ptcl擴展提供了php操作linux多進程的接口。

個人感覺swoole的多進程process方法更加方便一些。

關于兩者的比較:http://wiki.swoole.com/wiki/page/214.html

參考文章:
https://segmentfault.com/a/1190000002946586

更多關于PHP相關內(nèi)容感興趣的讀者可查看本站專題:《PHP進程與線程操作技巧總結》、《PHP網(wǎng)絡編程技巧總結》、《PHP基本語法入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

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

您可能感興趣的文章:
  • php多進程中的阻塞與非阻塞操作實例分析
  • php多進程并發(fā)編程防止出現(xiàn)僵尸進程的方法分析
  • php 的多進程操作實踐案例分析
  • php 多進程編程父進程的阻塞與非阻塞實例分析
  • php實現(xiàn)的簡單多進程服務器類完整示例
  • PHP多進程簡單實例小結
  • PHP 多進程與信號中斷實現(xiàn)多任務常駐內(nèi)存管理實例方法
  • php swoole多進程/多線程用法示例【基于php7nts版】
  • 詳解PHP多進程消費隊列

標簽:蚌埠 廣元 棗莊 大理 衢州 衡水 江蘇 萍鄉(xiāng)

巨人網(wǎng)絡通訊聲明:本文標題《PHP基于swoole多進程操作示例》,本文關鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    广河县| 昭苏县| 洛隆县| 保德县| 兴隆县| 土默特右旗| 慈利县| 龙川县| 醴陵市| 加查县| 张掖市| 和龙市| 海城市| 福贡县| 新河县| 九龙县| 中牟县| 涟水县| 弥勒县| 贡嘎县| 木兰县| 班戈县| 侯马市| 乡宁县| 大兴区| 承德县| 临漳县| 工布江达县| 东安县| 洱源县| 大关县| 奉新县| 海门市| 泽普县| 涞源县| 周宁县| 玉山县| 正宁县| 三明市| 云阳县| 肇东市|