首頁  >  文章  >  php框架  >  看看swoole多進程操作

看看swoole多進程操作

coldplay.xixi
coldplay.xixi轉載
2021-03-03 10:50:022383瀏覽

看看swoole多進程操作

多個任務同時執行

#將順序執行的任務,轉換為並行執行(任務在邏輯上可以並行執行)

例如,我們要對已知的用戶資料進行判斷,是否需要發送郵件和短信,如果需要發送則發送。

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

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

推薦(免費):swoole

<?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(&#39;sendMail&#39;,true);$mail_process->start();$sms_process = new swoole_process(&#39;sendSMS&#39;,true);$sms_process->start();//主进程输出子进程范围内容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;//并行函数function sendMail(swoole_process $worker){
    global $info;    if($info[&#39;sendmail&#39;]==1){
        sleep(2);        $worker->write("send mail to ".$info[&#39;mailto&#39;]);
    }
}function sendSMS(swoole_process $worker){
    global $info;    if($info[&#39;sendmail&#39;]==1){
        sleep(2);        $worker->write("send sms to ".$info[&#39;smsto&#39;]);
    }
}

看看swoole多進程操作

大任務分割成多個小任務

將循環執行的任務,分割為多個進程執行,提高工作效率

假設我們現在有一個透過curl抓取網頁內容的需求,需要抓取10個網頁,url位址透過陣列讀取,每個curl耗時2s。如果我們透過for循環來抓取這10個網頁,需要耗時20s,使用多進程我們可以將任務劃分成5份,分別由5個進程執行,每個進程抓取2個url,並發執行,共耗時4s,效率提高5倍。

<?php/**
 * Created by PhpStorm.
 * User: zhezhao
 * Date: 2016/10/20
 * Time: 10:51
 */$url_arr = array();for ($i=0;$i<10;$i++){    $url_arr[] = "www.baidu.com?wd=".$i;
}echo "start:".date("Y-m-d H:i:s").PHP_EOL;$workers = array();for ($i=0;$i<5;$i++){    $process = new swoole_process(&#39;getContents&#39;,true);    $process->start();    $process->write($i);    $workers[] = $process;
}//主进程数据结果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";
}

看看swoole多進程操作

總結

以上兩種情況,本質上都是將邏輯上沒有先後關係的任務,用多個進程程並發執行,提高效率。

php機製本身不提供多執行緒的操作,ptcl擴充提供了php操作linux多進程的介面。

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

以上是看看swoole多進程操作的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除