成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

記錄php daemon 進(jìn)程 遇到的問題--posix_setsid函數(shù)

浠ラ箍 / 1868人閱讀

摘要:則發(fā)現(xiàn)程序并不會完整輸出行數(shù)據(jù),只是部分?jǐn)?shù)據(jù)。如不關(guān)閉,將會浪費系統(tǒng)資源,這倒是小事,造成進(jìn)程所在的文件系統(tǒng)無法卸下以及引起無法預(yù)料的錯誤。所以需要關(guān)閉這些關(guān)閉標(biāo)準(zhǔn)輸入輸出與錯誤顯示。

總結(jié)一下先~

一個守護(hù)進(jìn)程一般需要root權(quán)限,因為可能要使用特殊端口1-1024及其他權(quán)限

一個守護(hù)進(jìn)程的父進(jìn)程會被fork之后被殺掉,所以可以說他的父進(jìn)程是init進(jìn)程。

一個守護(hù)進(jìn)程無需交互,也和終端(teriminalsession)無關(guān),所以任何輸出,無論是向標(biāo)準(zhǔn)輸出還是錯誤輸出,都需要特殊處理,涉及到的就是stdout和stderr

上代碼

下面是我用php 編寫一個守護(hù)進(jìn)程 demo


好下面我們執(zhí)行操作,輸出如下

root@tb:/home/tb/linuxing# php php_daemon.php 
fork succ
loop0
root@tb:/home/tb/linuxing# loop1
loop2
loop3
loop4
...
loop20

查看demo.txt

cat demo.txt 
0--2016-07-15 17:49:47
1--2016-07-15 17:49:48
2--2016-07-15 17:49:49
...
問題來了

貌似沒有問題,但是用以上php代碼,執(zhí)行后,馬上關(guān)閉當(dāng)前終端。則發(fā)現(xiàn)程序并不會完整輸出20行數(shù)據(jù),只是部分?jǐn)?shù)據(jù)。
問題復(fù)現(xiàn)步驟:
1.ubuntu終端Azhong 執(zhí)行 php php_daemon.php
2.關(guān)閉終端A
3.打開新終端B,ps -aux |grep php 發(fā)現(xiàn)無此進(jìn)程

如果手慢,自己把握時間或者調(diào)整for 次數(shù)。。

為什么呢

進(jìn)程從創(chuàng)建它的父進(jìn)程那里繼承了打開的文件描述符。如不關(guān)閉,將會浪費系統(tǒng)資源,(這倒是小事),造成進(jìn)程所在的文件系統(tǒng)無法卸下以及引起無法預(yù)料的錯誤。
所以需要關(guān)閉這些

    fclose(STDIN),fclose(STDOUT),fclose(STDERR)

關(guān)閉標(biāo)準(zhǔn)輸入輸出與錯誤顯示。

正確代碼之一

再解釋一下

如果想在關(guān)閉當(dāng)前終端后繼續(xù)執(zhí)行
需要關(guān)閉echo 那一行,因為當(dāng)然echo 和當(dāng)然session關(guān)聯(lián),sesssion關(guān)閉后,echo就會導(dǎo)致php致命錯誤,所以下面的file_put_contents不會執(zhí)行。

所以為了避免除顯示輸出的echo導(dǎo)致php錯誤的問題,我們一般建議這樣

      global $STDOUT, $STDERR;
      fclose(STDOUT);
      fclose(STDERR);
      $STDOUT = fopen("/dev/null", "rw+");
      $STDERR = fopen("/dev/null", "rw+");
      

加上上面那句,所有的顯示的不顯示的echo err之類都可以被忽略。也就是說你把
echo "loop" . $i . "n";這句加上也沒有問題
指到dev/null,,如果你不這樣,你的stdout會跟你的session有關(guān)。。
你的session一關(guān),你的stdout就失效,,echo就報錯了。

更優(yōu)處理辦法

感謝

三金 CFC4N

守護(hù)進(jìn)程詳解及創(chuàng)建,daemon()使用

不懂的太多

當(dāng)然這只是個例子,實際中還需要考慮目錄權(quán)限,umask,figchld信號。這些我還沒接觸。。。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/21776.html

相關(guān)文章

  • PHP進(jìn)程初探 --- 再次談daemon進(jìn)程

    摘要:因為子進(jìn)程一定不會是組長進(jìn)程,所以子進(jìn)程可以調(diào)用。主進(jìn)程退出子進(jìn)程繼續(xù)執(zhí)行啦啦啦,啦啦啦,啦啦啦,已經(jīng)變成啦,開心一般服務(wù)器軟件都有寫配置項,比如以模式運行還是以模式運行。 [原文地址:https://blog.ti-node.com/blog...] 其實前面是談過一次daemon進(jìn)程的,但是并涉及過多原理,但是并不影響使用。今天打算說說關(guān)于daemon進(jìn)程更多的二三事,本質(zhì)上說,如...

    fox_soyoung 評論0 收藏0
  • 守護(hù)進(jìn)程

    摘要:守護(hù)進(jìn)程為什么需要守護(hù)進(jìn)程呢普通進(jìn)程在運行時可以被控制終端發(fā)出的信號打斷而守護(hù)進(jìn)程由于脫離了控制終端所以不會被其打斷守護(hù)進(jìn)程創(chuàng)建的標(biāo)準(zhǔn)流程調(diào)用設(shè)置文件創(chuàng)建的掩碼子進(jìn)程并關(guān)閉父進(jìn)程調(diào)用創(chuàng)建新會話把當(dāng)前工作目錄切換為根目錄不需要的文件描述符全部 守護(hù)進(jìn)程 為什么需要守護(hù)進(jìn)程呢? 普通進(jìn)程在運行時可以被控制終端發(fā)出的信號打斷, 而守護(hù)進(jìn)程由于脫離了控制終端, 所以不會被其打斷. 守護(hù)進(jìn)程創(chuàng)建...

    Carbs 評論0 收藏0
  • PHP進(jìn)程系列筆記(四)

    摘要:本節(jié)主要講解常用函數(shù)和進(jìn)程池的概念,也會涉及到守護(hù)進(jìn)程的知識。所以任何時候,建議預(yù)先創(chuàng)建好進(jìn)程,也就是使用進(jìn)程池的方式實現(xiàn)。 本節(jié)主要講解Posix常用函數(shù)和進(jìn)程池的概念,也會涉及到守護(hù)進(jìn)程的知識。本節(jié)難度較低。 Posix常用函數(shù) posix_kill 向指定pid進(jìn)程發(fā)送信號。成功時返回 TRUE , 或者在失敗時返回 FALSE 。 bool posix_kill ( int $...

    Cc_2011 評論0 收藏0
  • workerman 簡要分析

    摘要:后面每開啟一個子進(jìn)程,會將子進(jìn)程的存儲到中,用來后面主進(jìn)程監(jiān)控子進(jìn)程,如果子進(jìn)程意外終止,主進(jìn)程可以重新佛。將當(dāng)前子進(jìn)程設(shè)置為會話組再次創(chuàng)建子進(jìn)程,為了防止在的系統(tǒng)下重新打開控制終端。 wokerman 啟動分析 @(學(xué)習(xí))[workerman, php] 前期想說的 也是最近才看的代碼,遇到不懂得地方就去google,所以這篇文章里面穿插了很多參考資料,可以直接點擊閱覽。 需要了解一...

    senntyou 評論0 收藏0
  • workerman筆記-php創(chuàng)建守護(hù)進(jìn)程

    摘要:守護(hù)進(jìn)程常常在系統(tǒng)引導(dǎo)裝入時啟動,在系統(tǒng)關(guān)閉時終止。進(jìn)程組有進(jìn)程組來唯一標(biāo)識。且該進(jìn)程組不會因組長進(jìn)程的退出而受到影響。 使用函數(shù) pcntl_fork();//創(chuàng)建子進(jìn)程 posix_setsid();//設(shè)置當(dāng)前進(jìn)程為進(jìn)程組長 posix_getpid();//獲取進(jìn)程id 例子 workerman中將進(jìn)程 /** * Run as deamon mode. * * @th...

    Cristic 評論0 收藏0

發(fā)表評論

0條評論

浠ラ箍

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<