PHP實現PCNTL多進程任務

PHP使用PCNTL系列的函數也能作到多進程處理一個事務。好比我須要從數據庫中獲取80w條的數據,再作一系列後續的處理,這個時候,用單進程?你能夠等到明年今天了。。。因此應該使用pcntl函數了。php

假設我想要啓動20個進程,將1-80w的數據分紅20份來作,主進程等待全部子進程都結束了才退出:html

$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數組就能夠讓主進程等候全部進程完結以後再結束了數組


進程間通訊函數

http://www.cnblogs.com/yjf512/p/4688451.html


守護進程this

http://my.oschina.net/neochen/blog/519156.net




署名葉劍峯(包含連接http://www.cnblogs.com/yjf512/)code

相關文章
相關標籤/搜索