php機制本身不提供多執行緒的操作,有了swoole就不一樣了
多個任務同時執行
比如,我們要對已知的使用者資料進行判斷,是否需要傳送郵件和簡訊,如果需要傳送則傳送。
不使用多程序時,我們首先判斷是否傳送郵件,如果需要則傳送;然後再判斷是否需要傳送簡訊,如果需要則傳送。如果傳送郵件耗時2s,傳送簡訊耗時2s,那麼我們完成任務大概需要4s左右的時間。
如果我們使用多執行緒的話,可以開兩個執行緒,一個用於處理郵件,一個用於處理簡訊,則耗時一共需要2s左右,處理時間縮短了一半。
以下是程式碼例項:
<?php /** * Created by PhpStorm. * User: cyw0413 * Date: 2018/10/20 * Time: 10:37 */ $info = array( "sendmail"=>1, "mailto"=>"[email protected]", "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(); //主程序輸出子程序範圍內容 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['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']); } }
大任務劃分成多個小任務
假設我們現在有一個通過curl抓取網頁內容的需求,需要抓取10個網頁,url地址通過陣列讀取,每個curl耗時2s。如果我們通過for迴圈來抓取這10個網頁,需要耗時20s,使用多程序我們可以將任務劃分成5份,分別由5個程序執行,每個程序抓取2個url,併發執行,共耗時4s,效率提高5倍。
以下是程式碼例項
<?php /** * Created by PhpStorm. * User: cyw0413 * Date: 2018/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; } //主程序資料結果 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"; }
總結
以上兩種情況,本質上都是將邏輯上沒有先後關係的任務,用多個程序程併發執行,提高效率。
php機制本身不提供多執行緒的操作,ptcl擴充套件提供了php操作linux多程序的介面。
點關注,不迷路
好了各位,以上就是這篇文章的全部內容了,能看到這裡的人呀,都是人才。之前說過,PHP方面的技術點很多,也是因為太多了,實在是寫不過來,寫過來了大家也不會看的太多,所以我這裡把它整理成了PDF和文件,如果有需要的可以
更多學習內容可以訪問【對標大廠】精品PHP架構師教程目錄大全,只要你能看完保證薪資上升一個臺階(持續更新)
以上內容希望幫助到大家,很多PHPer在進階的時候總會遇到一些問題和瓶頸,業務程式碼寫多了沒有方向感,不知道該從那裡入手去提升,對此我整理了一些資料,包括但不限於:分散式架構、高可擴充套件、高效能、高併發、伺服器效能調優、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql優化、shell指令碼、Docker、微服務、Nginx