PHP使用pcntl函數操作多進程的方法

來源:互聯網
上載者:User
這篇文章主要介紹了PHP的pcntl多進程用法,執行個體分析了pcntl操作多進程的提示,非常具有實用價值,需要的朋友可以參考下

本文執行個體講述了PHP的pcntl多進程用法。具體分析如下:

PHP使用PCNTL系列的函數也能做到多進程處理一個事務。比如我需要從資料庫中擷取80w條的資料,再做一系列後續的處理,這個時候,用單進程?你可以等到明年今天了。所以應該使用pcntl函數了。

假設我想要啟動20個進程,將1-80w的資料分成20份來做,主進程等待所有子進程都結束了才退出:

$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數組就可以讓主進程等候所有進程完結之後再結束了

總結:以上就是本篇文的全部內容,希望能對大家的學習有所協助。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.