"守護進程"(daemon)就是一直在后臺運行的進程(daemon)。
一、問題的由來
Web應用寫好后,下一件事就是啟動,讓它一直在后臺運行。
這并不容易。舉例來說,下面是一個最簡單的Node應用server.js,只有6行。
var http = require('http');http.createServer(function(req, res) { res.writeHead(200, {'Content-Type': 'text/plain'}); res.end('Hello World');}).listen(5000);你在命令行下啟動它。
$ node server.js
看上去一切正常,所有人都能快樂地訪問 5000 端口了。但是,一旦你退出命令行窗口,這個應用就一起退出了,無法訪問了。
怎么才能讓它變成系統的守護進程(daemon),成為一種服務(service),一直在那里運行呢?
二、前臺任務與后臺任務
上面這樣啟動的腳本,稱為"前臺任務"(foreground job)。它會獨占命令行窗口,只有運行完了或者手動中止,才能執行其他命令。
變成守護進程的第一步,就是把它改成"后臺任務"(background job)。
$ node server.js &
只要在命令的尾部加上符號&,啟動的進程就會成為"后臺任務"。如果要讓正在運行的"前臺任務"變為"后臺任務",可以先按ctrl + z,然后執行bg命令(讓最近一個暫停的"后臺任務"繼續執行)。
"后臺任務"有兩個特點。
可以看到,"后臺任務"與"前臺任務"的本質區別只有一個:是否繼承標準輸入。所以,執行后臺任務的同時,用戶還可以輸入其他命令。
三、SIGHUP信號
變為"后臺任務"后,一個進程是否就成為了守護進程呢?或者說,用戶退出 session 以后,"后臺任務"是否還會繼續執行?
Linux系統是這樣設計的。
上面的流程解釋了,為什么"前臺任務"會隨著 session 的退出而退出:因為它收到了SIGHUP信號。
那么,"后臺任務"是否也會收到SIGHUP信號?
這由 Shell 的huponexit參數決定的。
$ shopt | grep huponexit
執行上面的命令,就會看到huponexit參數的值。
大多數Linux系統,這個參數默認關閉(off)。因此,session 退出的時候,不會把SIGHUP信號發給"后臺任務"。所以,一般來說,"后臺任務"不會隨著 session 一起退出。
四、disown 命令
通過"后臺任務"啟動"守護進程"并不保險,因為有的系統的huponexit參數可能是打開的(on)。
更保險的方法是使用disown命令。它可以將指定任務從"后臺任務"列表(jobs命令的返回結果)之中移除。一個"后臺任務"只要不在這個列表之中,session 就肯定不會向它發出SIGHUP信號。
新聞熱點
疑難解答