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說明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)文章
php上傳圖片客戶端和服務(wù)器端實(shí)現(xiàn)方法
這篇文章主要介紹了php上傳圖片客戶端和服務(wù)器端實(shí)現(xiàn)方法,涉及php操作文件的技巧,涉及圖片后綴驗(yàn)證、文件重命名等常用方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03
PHP實(shí)現(xiàn)將視頻轉(zhuǎn)成MP4并獲取視頻預(yù)覽圖的方法
這篇文章主要介紹了PHP實(shí)現(xiàn)將視頻轉(zhuǎn)成MP4并獲取視頻預(yù)覽圖的方法,涉及php操作視頻文件的技巧,需要的朋友可以參考下2015-03-03
PHP采集相關(guān)教程之一 CURL函數(shù)庫(kù)
目前為目最全的CURL中文說明了,學(xué)PHP的要好好掌握。有很多的參數(shù)。大部份都很有用。真正掌握了它和正則,一定就是個(gè)采集高手了。2010-02-02
PHP面向?qū)ο蟪绦蛟O(shè)計(jì)之類常量用法實(shí)例
這篇文章主要介紹了PHP面向?qū)ο蟪绦蛟O(shè)計(jì)之類常量用法,是PHP面向?qū)ο蟪绦蛟O(shè)計(jì)中非常重要的一個(gè)概念,對(duì)于PHP初學(xué)者來(lái)說更是有必要加以牢固掌握,需要的朋友可以參考下2014-08-08

