PHP的pcntl多進(jìn)程用法實(shí)例
本文實(shí)例講述了PHP的pcntl多進(jìn)程用法。分享給大家供大家參考。具體分析如下:
PHP使用PCNTL系列的函數(shù)也能做到多進(jìn)程處理一個(gè)事務(wù)。比如我需要從數(shù)據(jù)庫(kù)中獲取80w條的數(shù)據(jù),再做一系列后續(xù)的處理,這個(gè)時(shí)候,用單進(jìn)程?你可以等到明年今天了。所以應(yīng)該使用pcntl函數(shù)了。
假設(shè)我想要啟動(dòng)20個(gè)進(jìn)程,將1-80w的數(shù)據(jù)分成20份來(lái)做,主進(jìn)程等待所有子進(jìn)程都結(jié)束了才退出:
$max = 800000; $workers = 20; $pids = array(); for($i = 0; $i < $workers; $i++){ $pids[$i] = pcntl_fork(); switch ($pids[$i]) { case -1: echo "fork error : {$i} \r\n"; exit; case 0: $param = array( 'lastid' => $max / $workers * $i, 'maxid' => $max / $workers * ($i+1), ); $this->executeWorker($input, $output, $param); exit; default: break; } } foreach ($pids as $i => $pid) { if($pid) { pcntl_waitpid($pid, $status); } }
這里當(dāng)pcntl_fork出來(lái)以后,會(huì)返回一個(gè)pid值,這個(gè)pid在子進(jìn)程中看是0,在父進(jìn)程中看是子進(jìn)程的pid(>0),如果pid為-1說(shuō)明fork出錯(cuò)了。
使用一個(gè)$pids數(shù)組就可以讓主進(jìn)程等候所有進(jìn)程完結(jié)之后再結(jié)束了
希望本文所述對(duì)大家的php程序設(shè)計(jì)有所幫助。
- php安裝swoole擴(kuò)展的方法
- PHP框架Swoole定時(shí)器Timer特性分析
- PHP+swoole實(shí)現(xiàn)簡(jiǎn)單多人在線聊天群發(fā)
- PHP使用SWOOLE擴(kuò)展實(shí)現(xiàn)定時(shí)同步 MySQL 數(shù)據(jù)
- 詳解PHP swoole process的使用方法
- PHP擴(kuò)展Swoole實(shí)現(xiàn)實(shí)時(shí)異步任務(wù)隊(duì)列示例
- PHP+swoole+linux實(shí)現(xiàn)系統(tǒng)監(jiān)控和性能優(yōu)化操作示例
- PHP下用Swoole實(shí)現(xiàn)Actor并發(fā)模型的方法
- PHP swoole和redis異步任務(wù)實(shí)現(xiàn)方法分析
- PHP使用pcntl_fork實(shí)現(xiàn)多進(jìn)程下載圖片的方法
- PHP基于swoole多進(jìn)程操作示例
相關(guān)文章
淺析虛擬主機(jī)服務(wù)器php fsockopen函數(shù)被禁用的解決辦法
以下是對(duì)虛擬主機(jī)服務(wù)器php fsockopen函數(shù)被禁用的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下2013-08-08php實(shí)現(xiàn)的redis緩存類(lèi)定義與使用方法示例
這篇文章主要介紹了php實(shí)現(xiàn)的redis緩存類(lèi),結(jié)合具體實(shí)例形式分析了php封裝的針對(duì)redis緩存類(lèi)定義與使用相關(guān)操作技巧,需要的朋友可以參考下2017-08-08php函數(shù)連續(xù)調(diào)用實(shí)例分析
這篇文章主要介紹了php函數(shù)連續(xù)調(diào)用的方法,以簡(jiǎn)單實(shí)例形式分析了php采用鏈?zhǔn)秸{(diào)用的方式連續(xù)調(diào)用函數(shù)的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07WordPress中編寫(xiě)自定義存儲(chǔ)字段的相關(guān)PHP函數(shù)解析
這篇文章主要介紹了WordPress中編寫(xiě)自定義字段的相關(guān)PHP函數(shù)解析,包括對(duì)不可見(jiàn)的自定義字段的相關(guān)介紹,需要的朋友可以參考下2015-12-12PHP依賴(lài)注入容器知識(shí)點(diǎn)淺析
在本篇文章里小編給大家分享的是一篇關(guān)于PHP依賴(lài)注入容器知識(shí)點(diǎn)內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。2020-01-01對(duì)php 判斷http還是https,以及獲得當(dāng)前url的方法詳解
今天小編就為大家分享一篇對(duì)php 判斷http還是https,以及獲得當(dāng)前url的方法詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01php基礎(chǔ)知識(shí):類(lèi)與對(duì)象(1)
php基礎(chǔ)知識(shí):類(lèi)與對(duì)象(1)...2006-12-12學(xué)習(xí)php設(shè)計(jì)模式 php實(shí)現(xiàn)備忘錄模式(Memento)
這篇文章主要介紹了php設(shè)計(jì)模式中的備忘錄模式,使用php實(shí)現(xiàn)備忘錄模式,感興趣的小伙伴們可以參考一下2015-12-12