php實現多進程、多線程

來源:互聯網
上載者:User

標籤: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實現多進程、多線程

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.