PHP的pcntl多進程用法實例
本文實例講述了PHP的pcntl多進程用法。分享給大家供大家參考。具體分析如下:
PHP使用PCNTL系列的函數(shù)也能做到多進程處理一個事務(wù)。比如我需要從數(shù)據(jù)庫中獲取80w條的數(shù)據(jù),再做一系列后續(xù)的處理,這個時候,用單進程?你可以等到明年今天了。所以應(yīng)該使用pcntl函數(shù)了。
假設(shè)我想要啟動20個進程,將1-80w的數(shù)據(jù)分成20份來做,主進程等待所有子進程都結(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);
}
}
這里當pcntl_fork出來以后,會返回一個pid值,這個pid在子進程中看是0,在父進程中看是子進程的pid(>0),如果pid為-1說明fork出錯了。
使用一個$pids數(shù)組就可以讓主進程等候所有進程完結(jié)之后再結(jié)束了
希望本文所述對大家的php程序設(shè)計有所幫助。
- php安裝swoole擴展的方法
- PHP框架Swoole定時器Timer特性分析
- PHP+swoole實現(xiàn)簡單多人在線聊天群發(fā)
- PHP使用SWOOLE擴展實現(xiàn)定時同步 MySQL 數(shù)據(jù)
- 詳解PHP swoole process的使用方法
- PHP擴展Swoole實現(xiàn)實時異步任務(wù)隊列示例
- PHP+swoole+linux實現(xiàn)系統(tǒng)監(jiān)控和性能優(yōu)化操作示例
- PHP下用Swoole實現(xiàn)Actor并發(fā)模型的方法
- PHP swoole和redis異步任務(wù)實現(xiàn)方法分析
- PHP使用pcntl_fork實現(xiàn)多進程下載圖片的方法
- PHP基于swoole多進程操作示例
相關(guān)文章
淺析虛擬主機服務(wù)器php fsockopen函數(shù)被禁用的解決辦法
以下是對虛擬主機服務(wù)器php fsockopen函數(shù)被禁用的解決方法進行了詳細的分析介紹,需要的朋友可以過來參考下2013-08-08
WordPress中編寫自定義存儲字段的相關(guān)PHP函數(shù)解析
這篇文章主要介紹了WordPress中編寫自定義字段的相關(guān)PHP函數(shù)解析,包括對不可見的自定義字段的相關(guān)介紹,需要的朋友可以參考下2015-12-12
對php 判斷http還是https,以及獲得當前url的方法詳解
今天小編就為大家分享一篇對php 判斷http還是https,以及獲得當前url的方法詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-01-01
學(xué)習(xí)php設(shè)計模式 php實現(xiàn)備忘錄模式(Memento)
這篇文章主要介紹了php設(shè)計模式中的備忘錄模式,使用php實現(xiàn)備忘錄模式,感興趣的小伙伴們可以參考一下2015-12-12

