標籤:php pre 進程 並行 收集 div exe array 殭屍進程
孤兒進程:一個父進程退出,而它的一個或多個子進程還在運行,那麼那些子進程將成為孤兒進程。孤兒進程將被init進程(進程號為1)所收養,並由init進程對它們完成狀態收集工作。
殭屍進程:一個進程使用fork建立子進程,如果子進程退出,而父進程並沒有調用wait或waitpid擷取子進程的狀態資訊,那麼子進程的進程描述符仍然儲存在系統中。這種進程稱之為僵死進程。
殭屍進程危害:如果進程不調用wait / waitpid的話, 那麼保留的那段資訊就不會釋放,其進程號就會一直被佔用,但是系統所能使用的進程號是有限的,如果大量的產生僵死進程,將因為沒有可用的進程號而導致系統不能產生新的進程. 此即為殭屍進程的危害,應當避免。任何一個子進程(init除外)在exit()之後,並非馬上就消失掉,而是留下一個稱為殭屍進程(Zombie)的資料結構,等待父進程處理。
已經產生的殭屍進程,解決方案:kill掉父進程,它產生的僵死進程就變成了孤兒進 程,這些孤兒進程會被init進程接管,init進程會wait()這些孤兒進程,釋放它們佔用的系統進程表中的資源。
殭屍進程解決辦法
(1)通過訊號機制
子進程退出時向父進程發送SIGCHILD訊號,父進程處理SIGCHILD訊號。在訊號處理函數中調用wait進行處理殭屍進程。
(2)fork兩次
《Unix 環境進階編程》8.6節說的非常詳細。原理是將子進程成為孤兒進程,從而其的父進程變為init進程,通過init進程可以處理殭屍進程。
1. [代碼]PHP實現多進程並行操作(可做守護進程)
1 /** 2 * 入口函數 3 * 將此檔案儲存為 ProcessOpera.php 4 * 在terminal中運行 /usr/local/php/bin/php ProcessOpera.php & 5 * 查看進程 ps aux|grep php 6 */ 7 8 9 ProcessOpera("runCode", array(), 8);10 11 /**12 * run Code13 */14 function runCode($opt = array()) {15 //需要在守護進程中啟動並執行代碼16 }17 18 /**19 * $func為子進程執行具體事物的函數名稱20 * $opt為$func的參數 數組形式21 * $pNum 為fork的子進程數量22 */23 function ProcessOpera($func, $opts = array(), $pNum = 1) {24 while(true) {25 $pid = pcntl_fork();26 if($pid == -1) {27 exit("pid fork error");28 } 29 if($pid) {30 static $execute = 0;31 $execute++;32 if($execute >= $pNum) {33 pcntl_wait($status);34 $execute--;35 } 36 } else {37 while(true) {38 //somecode39 $func($opts);40 sleep(1);41 } 42 exit(0);43 } 44 } 45 }
php實現多進程、多線程