好比,咱們要對已知的用戶數據進行判斷,是否須要發送郵件和短信,若是須要發送則發送。php
不使用多進程時,咱們首先判斷是否發送郵件,若是須要則發送;而後再判斷是否須要發送短信,若是須要則發送。若是發送郵件耗時2s,發送短信耗時2s,那麼咱們完成任務大概須要4s左右的時間。linux
若是咱們使用多線程的話,能夠開兩個線程,一個用於處理郵件,一個用於處理短信,則耗時一共須要2s左右,處理時間縮短了一半。laravel
如下是代碼實例:sql
<?php /** * Created by PhpStorm. * User: cyw0413 * Date: 2018/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(); //主進程輸出子進程範圍內容 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倍。shell
如下是代碼實例數組
<?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多進程的接口。swoole
好了各位,以上就是這篇文章的所有內容了,能看到這裏的人呀,都是人才。以前說過,PHP方面的技術點不少,也是由於太多了,實在是寫不過來,寫過來了你們也不會看的太多,因此我這裏把它整理成了PDF和文檔,若是有須要的能夠多線程
更多學習內容能夠訪問【對標大廠】精品PHP架構師教程目錄大全,只要你能看完保證薪資上升一個臺階(持續更新)
以上內容但願幫助到你們,不少PHPer在進階的時候總會遇到一些問題和瓶頸,業務代碼寫多了沒有方向感,不知道該從那裏入手去提高,對此我整理了一些資料,包括但不限於:分佈式架構、高可擴展、高性能、高併發、服務器性能調優、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql優化、shell腳本、Docker、微服務、Nginx等多個知識點高級進階乾貨須要的能夠免費分享給你們,須要的能夠加入個人 PHP技術交流羣