### Nohup命令
每個開發者都會躺過這個坑,在命令行跑一個后臺程序,關閉終端后發現進程也退出了,網上搜一下發現要用`nohup`,究竟什么原因呢?
原來普通進程運行時默認會綁定TTY(虛擬終端),關閉終端后系統會給上面所有進程發送TERM信號,這時普通進程也就退出了。當然還有些進程不會退出,這就是后面將會提到的守護進程。
`Nohup`的原理也很簡單,終端關閉后會給此終端下的每一個進程發送SIGHUP信號,而使用`nohup`運行的進程則會忽略這個信號,因此終端關閉后進程也不會退出。
### 舉個例子
我們用Go實現最簡單的Web服務器,代碼web_server.go如下。
~~~
package main
import (
"fmt"
"net/http"
)
func handler(w http.ResponseWriter, r *http.Request) {
fmt.Println("Handle request")
}
func main() {
http.HandleFunc("/", handler)
http.ListenAndServe(":8000", nil)
}
~~~
然后在終端上運行,并測試一下。
~~~
? go build web_server.go
? ./web_server &
[1] 25967
? wget 127.0.0.1:8000
--2014-12-28 22:24:07-- http://127.0.0.1:8003/
Connecting to 127.0.0.1:8003... connected.
HTTP request sent, awaiting response... 200 OK
Length: 5 [text/plain]
Saving to: 'index.html.4'
100%[======================>] 5 --.-K/s in 0s
2014-12-28 22:24:07 (543 KB/s) - 'index.html' saved [5/5]
~~~
如果關閉終端,`curl`命令就連不上我們的Web服務器了。如果使用`nohup`運行呢?
~~~
? go build web_server.go
? nohup ./web_server &
[1] 25968
? exit
? wget 127.0.0.1:8003
--2014-12-28 22:24:11-- http://127.0.0.1:8003/
~~~
發現關閉終端對Web服務器進程沒有任何影響,這正是我們預期的。這是運行守護進程最簡單的方法,實際上標準的守護進程除了處理信號外,還要考慮這種因素,后面將會詳述。
- 前言
- 致謝
- 概述
- 使用代碼
- 使用Docker
- 進程基礎
- 進程是什么
- Hello World
- PID
- PPID
- 使用PID
- 進程名字
- 進程參數
- 輸入與輸出
- 并發與并行
- 進程越多越好
- 進程狀態
- 退出碼
- 進程資源
- 死鎖
- 活鎖
- POSIX
- Nohup
- 運行進程
- Go編程實例
- 衍生新進程
- 執行外部程序
- 復制進程
- 進程進階
- 文件鎖
- 孤兒進程
- 僵尸進程
- 守護進程
- 進程間通信
- 信號
- Linux系統調用
- 文件描述符
- Epoll
- 共享內存
- Copy On Write
- Cgroups
- Namespaces
- 項目實例Run
- 項目架構
- 代碼實現
- 注意事項
- 創建目錄權限
- 捕獲SIGKILL
- Sendfile系統調用
- 后記
- 參考書籍
- 項目學習
- 再次感謝