PHP基于swoole多進(jìn)程操作示例
本文實(shí)例講述了PHP基于swoole多進(jìn)程操作。分享給大家供大家參考,具體如下:
多個(gè)任務(wù)同時(shí)執(zhí)行
將順序執(zhí)行的任務(wù),轉(zhuǎn)化為并行執(zhí)行(任務(wù)在邏輯上可以并行執(zhí)行)
比如,我們要對已知的用戶數(shù)據(jù)進(jìn)行判斷,是否需要發(fā)送郵件和短信,如果需要發(fā)送則發(fā)送。
不使用多進(jìn)程時(shí),我們首先判斷是否發(fā)送郵件,如果需要?jiǎng)t發(fā)送;然后再判斷是否需要發(fā)送短信,如果需要?jiǎng)t發(fā)送。如果發(fā)送郵件耗時(shí)2s,發(fā)送短信耗時(shí)2s,那么我們完成任務(wù)大概需要4s左右的時(shí)間。
如果我們使用多線程的話,可以開兩個(gè)線程,一個(gè)用于處理郵件,一個(gè)用于處理短信,則耗時(shí)一共需要2s左右,處理時(shí)間縮短了一半。
<?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(); //主進(jìn)程輸出子進(jìn)程范圍內(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']); } }
大任務(wù)劃分成多個(gè)小任務(wù)
將循環(huán)執(zhí)行的任務(wù),劃分為多個(gè)進(jìn)程執(zhí)行,提高工作效率
假設(shè)我們現(xiàn)在有一個(gè)通過curl抓取網(wǎng)頁內(nèi)容的需求,需要抓取10個(gè)網(wǎng)頁,url地址通過數(shù)組讀取,每個(gè)curl耗時(shí)2s。如果我們通過for循環(huán)來抓取這10個(gè)網(wǎng)頁,需要耗時(shí)20s,使用多進(jìn)程我們可以將任務(wù)劃分成5份,分別由5個(gè)進(jìn)程執(zhí)行,每個(gè)進(jìn)程抓取2個(gè)url,并發(fā)執(zhí)行,共耗時(shí)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('getContents',true); $process->start(); $process->write($i); $workers[] = $process; } //主進(jìn)程數(shù)據(jù)結(jié)果 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"; }
總結(jié)
以上兩種情況,本質(zhì)上都是將邏輯上沒有先后關(guān)系的任務(wù),用多個(gè)進(jìn)程程并發(fā)執(zhí)行,提高效率。
php機(jī)制本身不提供多線程的操作,ptcl擴(kuò)展提供了php操作linux多進(jìn)程的接口。
個(gè)人感覺swoole的多進(jìn)程process方法更加方便一些。
關(guān)于兩者的比較:http://wiki.swoole.com/wiki/page/214.html
參考文章:
https://segmentfault.com/a/1190000002946586
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP進(jìn)程與線程操作技巧總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語法入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
Javascript與PHP驗(yàn)證用戶輸入U(xiǎn)RL地址是否正確
這篇文章主要介紹了Javascript與PHP驗(yàn)證用戶輸入U(xiǎn)RL地址是否正確,在進(jìn)行web應(yīng)用程序開發(fā)時(shí)非常實(shí)用,需要的朋友可以參考下2014-10-10php實(shí)現(xiàn)的css文件背景圖片下載器代碼
這篇文章主要介紹了php實(shí)現(xiàn)的css文件背景圖片下載器代碼,涉及文件與URL地址的操作,是非常實(shí)用的技巧,需要的朋友可以參考下2014-11-11php 驗(yàn)證碼(傾斜,正弦干擾線,黏貼,旋轉(zhuǎn))
本篇文章是對php 驗(yàn)證碼(傾斜,正弦干擾線,黏貼,旋轉(zhuǎn))進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06PHP實(shí)現(xiàn)二維數(shù)組按照指定的字段進(jìn)行排序算法示例
這篇文章主要介紹了PHP實(shí)現(xiàn)二維數(shù)組按照指定的字段進(jìn)行排序算法,涉及php針對數(shù)組的遍歷、排序等相關(guān)操作技巧,需要的朋友可以參考下2019-04-04