主頁 > 知識庫 > PHP多進程編程之僵尸進程問題的理解

PHP多進程編程之僵尸進程問題的理解

熱門標簽:施工地圖標注怎么做 個性化地圖標注在線 怎么在高德地圖標注行走軌跡 襄陽房產(chǎn)電銷機器人招商 百度地圖標注名編輯 清遠陽山400電話號碼如何申請 百度地圖標注飯店位置怎么 安徽移動外呼系統(tǒng) 深圳400電話辦理那家好

PHP多進程編程之僵尸進程問題的理解

使用pcntl_fork函數(shù)可以讓PHP實現(xiàn)多進程并發(fā)或者異步處理的效果:https://www.jb51.net/article/125789.htm

那么問題是我們產(chǎn)生的進程需要去控制,而不能置之不理。最基本的方式就是fork進程和殺死進程。

通過利用pcntl_fork函數(shù),我們已經(jīng)有了新的子進程,而子進程接下來完成我們需要處理的內(nèi)容,那么我們就暫且叫做service()吧,而且我們需要很多個service()進行處理,再次參照我們之前的需求,父進程需要一直循環(huán)讀取配置文件,等待文件發(fā)生改變。通過對pcntl_fork的方式,很容易我們就可以寫出如下代碼:

$res = config();
//kill進程
for($i = 0; $i  $res[sum]; $i++) {
  $pid = pcntl_fork();
  if ($pid == 0) {
    service();
    return;
  }
}

代碼中注釋的地方我們需要在配置文件中發(fā)生改變的時候殺死進程,殺死進程的的方式很簡單,可以使用kill命令直接殺死,比如(假設(shè)pid為123):

1 kill 123

但是我們發(fā)現(xiàn),使用這個殺死進程的方式并沒有真正的把進程殺死,這個子進程被殺死后還占用這個進程的資源,我們成為僵尸進程,僵尸進程是使用kill命令無法殺死的。想要解決這個問題,我們能做的只有兩種方式。

1. shutdown

2. 殺死該進程的父進程。

但是這兩種方法都不行,因為這個程序的目的是監(jiān)控常駐在服務(wù)器內(nèi),服務(wù)器不能關(guān)閉,并且父進程也不能被干掉。這時候我們看到了官方文檔對于fork方法的解釋:

pcntl_wait($status); //等待子進程中斷,防止子進程成為僵尸進程。

原來有種方式可以防止進程成為僵尸進程,但是,官網(wǎng)給出的代碼是這樣子的:

$pid = pcntl_fork();
//父進程和子進程都會執(zhí)行下面代碼
if ($pid == -1) {
  //錯誤處理:創(chuàng)建子進程失敗時返回-1.
   die('could not fork');
} else if ($pid) {
   //父進程會得到子進程號,所以這里是父進程執(zhí)行的邏輯
   pcntl_wait($status); //等待子進程中斷,防止子進程成為僵尸進程。
} else {
   //子進程得到的$pid為0, 所以這里是子進程執(zhí)行的邏輯。
}

什么意思呢?就是父進程會等待子進程運行,等子進程運行結(jié)束之后,才會進行下一步,并且也會消除僵尸進程。但是這里又和我們的需求不符合了,我們的子進程為一個死循環(huán)的程序,不斷的查找輸出,更本沒有結(jié)束的時候,并且我們需要的是異步處理而不是同步。但是這個方法可以用嗎?其實當然可以。

在pcntl_wait的文檔中是這么解釋這個函數(shù)的:

wait函數(shù)刮起當前進程的執(zhí)行直到一個子進程退出或接收到一個信號要求中斷當前進程或調(diào)用一個信號處理函數(shù)。 如果一個子進程在調(diào)用此函數(shù)時已經(jīng)退出(俗稱僵尸進程),此函數(shù)立刻返回。子進程使用的所有系統(tǒng)資源將 被釋放。關(guān)于wait在您系統(tǒng)上工作的詳細規(guī)范請查看您系統(tǒng)的wait(2)手冊。

我們發(fā)現(xiàn),當這個函數(shù)發(fā)現(xiàn)子進程成為了僵尸進程就會釋放僵尸進程的資源——前提是這個僵尸進程為這個父進程的子進程。那么我們就可以巧妙的利用這個方式讓這些僵尸進程釋放資源了,所以就有了如下代碼:

 posix_kill(123, 9);
 pcntl_wait($status);

這樣我們先使用kill干掉這個進程,這個進程就不會再運行了,但是這個進程成為了僵尸進程,占用著資源,我們下一句就執(zhí)行一次pcntl_wait()讓這些僵尸進程釋放資源,這樣,子進程才真正的被終止了,僵尸進程被消除了。

如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

您可能感興趣的文章:
  • PHP如何限制定時任務(wù)的進程數(shù)量
  • php多進程中的阻塞與非阻塞操作實例分析
  • php多進程并發(fā)編程防止出現(xiàn)僵尸進程的方法分析
  • PHP多進程之pcntl_fork的實例詳解
  • PHP基于文件鎖解決多進程同時讀寫一個文件問題示例
  • PHP守護進程的兩種常見實現(xiàn)方式詳解
  • php中實現(xiàn)進程鎖與多進程的方法
  • PHP多進程編程總結(jié)(推薦)
  • 詳解PHP調(diào)用Go服務(wù)的正確方式

標簽:黑河 欽州 阜陽 南昌 駐馬店 臨夏 中衛(wèi) 延邊

巨人網(wǎng)絡(luò)通訊聲明:本文標題《PHP多進程編程之僵尸進程問題的理解》,本文關(guān)鍵詞  PHP,多,進程,編程,之,僵尸,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP多進程編程之僵尸進程問題的理解》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP多進程編程之僵尸進程問題的理解的相關(guān)信息資訊供網(wǎng)民參考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推薦文章