您好,登錄后才能下訂單哦!
PHP使用PCNTL系列的函數(shù)也能做到多進(jìn)程處理一個(gè)事務(wù)。比如我需要從數(shù)據(jù)庫(kù)中獲取80w條的數(shù)據(jù),再做一系列后續(xù)的處理,這個(gè)時(shí)候,用單進(jìn)程?你可以等到明年今天了。。。所以應(yīng)該使用pcntl函數(shù)了。
必須在php+msyql+apache+linux即lamp環(huán)境下,否則會(huì)出現(xiàn)函數(shù)未定義的錯(cuò)誤。
假設(shè)我想要啟動(dòng)20個(gè)進(jìn)程,將1-80w的數(shù)據(jù)分成20份來(lái)做,主進(jìn)程等待所有子進(jìn)程都結(jié)束了才退出。
<?php $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_wait($status, WNOHANG); } } ?>
這里當(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é)束了
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。