2019-08-29

解決Linux關(guān)閉終端(關(guān)閉SSH等)后運(yùn)行的程序或者服務(wù)自動(dòng)停止【后臺(tái)運(yùn)行程序】



問題描述:當(dāng)SSH遠(yuǎn)程連接到服務(wù)器上奄薇,然后運(yùn)行一個(gè)服務(wù) ./catalina.sh start星持,然后把終端開閉(切斷SSH連接)之后帆竹,發(fā)現(xiàn)該服務(wù)中斷柄错,導(dǎo)致網(wǎng)頁無法訪問。

解決方法:使用nohup命令讓程序在關(guān)閉窗口(切換SSH連接)的時(shí)候程序還能繼續(xù)在后臺(tái)運(yùn)行涨共。

Unix/Linux下一般比如想讓某個(gè)程序在后臺(tái)運(yùn)行测暗,很多都是使用& 在程序結(jié)尾來讓程序自動(dòng)運(yùn)行。比如我們要運(yùn)行mysql在后臺(tái):

/usr/local/mysql/bin/mysqld_safe --user=mysql &

但是加入我們很多程序并不象mysqld一樣做成守護(hù)進(jìn)程蚂踊,可能我們的程序只是普通程序而已扼睬,一般這種程序使用& 結(jié)尾,但是如果終端關(guān)閉悴势,那么程序也會(huì)被關(guān)閉。但是為了能夠后臺(tái)運(yùn)行措伐,那么我們就可以使用nohup這個(gè)命令特纤,比如我們有個(gè)test.php需要在后臺(tái)運(yùn)行,并且希望在后臺(tái)能夠定期運(yùn)行侥加,那么就使用nohup:

   nohup /root/test.php &

提示:

[~]$ appending output to nohup.out

嗯捧存,證明運(yùn)行成功,同時(shí)把程序運(yùn)行的輸出信息放到當(dāng)前目錄的nohup.out 文件中去。

nohup命令說明:

用途:不掛斷地運(yùn)行命令昔穴。

語法:nohup Command [ Arg ... ] [ & ]

描述:nohup 命令運(yùn)行由 Command 參數(shù)和任何相關(guān)的 Arg 參數(shù)指定的命令镰官,忽略所有掛斷(SIGHUP)信號(hào)。在注銷后使用 nohup 命令運(yùn)行后臺(tái)中的程序吗货。要運(yùn)行后臺(tái)中的 nohup 命令泳唠,添加 & ( 表示“and”的符號(hào))到命令的尾部。

無論是否將 nohup 命令的輸出重定向到終端宙搬,輸出都將附加到當(dāng)前目錄的 nohup.out 文件中笨腥。如果當(dāng)前目錄的 nohup.out 文件不可寫,輸出重定向到 $HOME/nohup.out 文件中勇垛。如果沒有文件能創(chuàng)建或打開以用于追加脖母,那么 Command 參數(shù)指定的命令不可調(diào)用。如果標(biāo)準(zhǔn)錯(cuò)誤是一個(gè)終端闲孤,那么把指定的命令寫給標(biāo)準(zhǔn)錯(cuò)誤的所有輸出作為標(biāo)準(zhǔn)輸出重定向到相同的文件描述符谆级。

退出狀態(tài):該命令返回下列出口值:

126 可以查找但不能調(diào)用 Command 參數(shù)指定的命令。

127 nohup 命令發(fā)生錯(cuò)誤或不能查找由 Command 參數(shù)指定的命令讼积。

否則肥照,nohup 命令的退出狀態(tài)是 Command 參數(shù)指定命令的退出狀態(tài)。

nohup命令及其輸出文件

nohup命令:如果你正在運(yùn)行一個(gè)進(jìn)程币砂,而且你覺得在退出帳戶時(shí)該進(jìn)程還不會(huì)結(jié)束建峭,那么可以使用nohup命令。該命令可以在你退出帳戶/關(guān)閉終端之后繼續(xù)運(yùn)行相應(yīng)的進(jìn)程决摧。nohup就是不掛起的意思( n ohang up)亿蒸。

該命令的一般形式為:nohup command &

使用nohup命令提交作業(yè)

如果使用nohup命令提交作業(yè),那么在缺省情況下該作業(yè)的所有輸出都被重定向到一個(gè)名為nohup.out的文件中掌桩,除非另外指定了輸出文件:(也就是說自定義輸出的文件名)

nohup command > myout.file 2>&1 &

在上面的例子中边锁,輸出被重定向到myout.file文件中。

使用 jobs 查看任務(wù)波岛。

使用 fg %n 關(guān)閉茅坛。

另外有兩個(gè)常用的ftp工具ncftpget和ncftpput,可以實(shí)現(xiàn)后臺(tái)的ftp上傳和下載则拷,這樣我就可以利用這些命令在后臺(tái)上傳和下載文件了贡蓖。

思考:?jiǎn)栴}1為什么ssh一關(guān)閉,程序就不再運(yùn)行了煌茬?

元兇:SIGHUP 信號(hào)
讓我們來看看為什么關(guān)掉窗口/斷開連接會(huì)使得正在運(yùn)行的程序死掉斥铺。

在Linux/Unix中,有這樣幾個(gè)概念:
進(jìn)程組(process group):一個(gè)或多個(gè)進(jìn)程的集合坛善,每一個(gè)進(jìn)程組有唯一一個(gè)進(jìn)程組ID晾蜘,即進(jìn)程組長(zhǎng)進(jìn)程的ID邻眷。
會(huì)話期(session):一個(gè)或多個(gè)進(jìn)程組的集合,有唯一一個(gè)會(huì)話期首進(jìn)程(session leader)剔交。會(huì)話期ID為首進(jìn)程的ID肆饶。
會(huì)話期可以有一個(gè)單獨(dú)的控制終端(controlling terminal)。與控制終端連接的會(huì)話期首進(jìn)程叫做控制進(jìn)程(controlling process)岖常。當(dāng)前與終端交互的進(jìn)程稱為前臺(tái)進(jìn)程組驯镊。其余進(jìn)程組稱為后臺(tái)進(jìn)程組。
根據(jù)POSIX.1定義:
掛斷信號(hào)(SIGHUP)默認(rèn)的動(dòng)作是終止程序腥椒。
當(dāng)終端接口檢測(cè)到網(wǎng)絡(luò)連接斷開阿宅,將掛斷信號(hào)發(fā)送給控制進(jìn)程(會(huì)話期首進(jìn)程)。
如果會(huì)話期首進(jìn)程終止笼蛛,則該信號(hào)發(fā)送到該會(huì)話期前臺(tái)進(jìn)程組洒放。
一個(gè)進(jìn)程退出導(dǎo)致一個(gè)孤兒進(jìn)程組中產(chǎn)生時(shí),如果任意一個(gè)孤兒進(jìn)程組進(jìn)程處于STOP狀態(tài)滨砍,發(fā)送SIGHUP和SIGCONT信號(hào)到該進(jìn)程組中所有進(jìn)程往湿。(關(guān)于孤兒進(jìn)程參照:http://blog.csdn.net/hmsiwtv/article/details/7901711** )**
結(jié)論:因此當(dāng)網(wǎng)絡(luò)斷開或終端窗口關(guān)閉后,也就是SSH斷開以后惋戏,控制進(jìn)程收到SIGHUP信號(hào)退出领追,會(huì)導(dǎo)致該會(huì)話期內(nèi)其他進(jìn)程退出。

簡(jiǎn)而言之:就是ssh 打開以后响逢,bash等都是他的子程序绒窑,一旦ssh關(guān)閉,系統(tǒng)將所有相關(guān)進(jìn)程殺掉L蛲ぁ些膨! 導(dǎo)致一旦ssh關(guān)閉,執(zhí)行中的任務(wù)就取消了

例子:
我們來看一個(gè)例子钦铺。打開兩個(gè)SSH終端窗口订雾,在其中一個(gè)運(yùn)行top命令。
[root@tivf09 root]# top

在另一個(gè)終端窗口矛洞,找到top的進(jìn)程ID為5180洼哎,其父進(jìn)程ID為5128,即登錄shell沼本。
[root@tivf09 root]# ps -ef|grep top
root 5180 5128 0 01:03 pts/0 00:00:02 top
root 5857 3672 0 01:12 pts/2 00:00:00 grep top

使用pstree命令可以更清楚地看到這個(gè)關(guān)系:
[root@tivf09 root]# pstree -H 5180|grep top
|-sshd-+-sshd---bash---top

使用ps-xj命令可以看到噩峦,登錄shell(PID 5128)和top在同一個(gè)會(huì)話期,shell為會(huì)話期首進(jìn)程抽兆,所在進(jìn)程組PGID為5128壕探,top所在進(jìn)程組PGID為5180,為前臺(tái)進(jìn)程組郊丛。
[root@tivf09 root]# ps -xj|grep 5128
5126 5128 5128 5128 pts/0 5180 S 0 0:00 -bash
5128 5180 5180 5128 pts/0 5180 S 0 0:50 top
3672 18095 18094 3672 pts/2 18094 S 0 0:00 grep 5128

關(guān)閉第一個(gè)SSH窗口李请,在另一個(gè)窗口中可以看到top也被殺掉了。
[root@tivf09 root]# ps -ef|grep 5128
root 18699 3672 0 04:35 pts/2 00:00:00 grep 5128

問題2 為什么守護(hù)程序就算ssh 打開的厉熟,就算關(guān)閉ssh也不會(huì)影響其運(yùn)行导盅?
因?yàn)樗麄兊某绦蛱厥猓热鏷ttpd –k start運(yùn)行這個(gè)以后揍瑟,他不屬于sshd這個(gè)進(jìn)程組 而是單獨(dú)的進(jìn)程組白翻,所以就算關(guān)閉了ssh,和他也沒有任何關(guān)系绢片!
[root@CentOS5-4 ~]# pstree |grep http
|-httpd
[root@CentOS5-4 ~]# pstree |grep top
|-sshd-+-sshd---bash---top

結(jié)論:守護(hù)進(jìn)程的啟動(dòng)命令本身就是特殊的滤馍,和一般命令不同的,比如mysqld_safe 這樣的命令 一旦使用了 就是守護(hù)進(jìn)程運(yùn)行底循。所以想把一般程序改造為守護(hù)程序是不可能巢株,

問題3 使用后臺(tái)運(yùn)行命令& 能否將程序擺脫ssh進(jìn)程組控制呢 也就是ssh關(guān)閉,后臺(tái)程序繼續(xù)運(yùn)行熙涤?
我們做一個(gè)試驗(yàn): find / -name ‘http’&
利用ctrl+d 注銷以后 再進(jìn)入系統(tǒng) 會(huì)不會(huì)看見這個(gè)命令再運(yùn)行?
答案是 :命令被中止了!!

因?yàn)樗廊粚儆谶@個(gè)ssh進(jìn)程組 就算加了&也無法擺脫8蟀!
[root@CentOS5-4 ~]# pstree |grep find
|-sshd-+-sshd---bash---find

結(jié)論就是:只要是ssh 打開執(zhí)行的一般命令祠挫,不是守護(hù)程序那槽,無論加不加&,一旦關(guān)閉ssh等舔,系統(tǒng)就會(huì)用SIGHUP終止

問題4 nohup能解決的問題
但是為了能夠再注銷以后 依然能后臺(tái)運(yùn)行骚灸,那么我們就可以使用nohup這個(gè)命令,我們現(xiàn)在開始查找find / -name ‘http’&
慌植,并且希望在后臺(tái)運(yùn)行甚牲,
那么就使用nohup:nohup find / -name "httpd"
此時(shí)默認(rèn)地程序運(yùn)行的輸出信息放到當(dāng)前文件夾的nohup.out 文件中去
加不加&并不會(huì)影響這個(gè)命令 只是讓程序 前臺(tái)或者后臺(tái)運(yùn)行而已

延伸:Linux命令nohup+screen命令

如果想在關(guān)閉ssh連接后剛才啟動(dòng)的程序繼續(xù)運(yùn)行怎么辦,可以使用nohup涤浇。但是如果要求第二天來的時(shí)候鳖藕,一開ssh,還能查看到昨天運(yùn)行的程序的狀態(tài)只锭,然后繼續(xù)工作著恩,這時(shí)nohup是不行了,需要使用screen來達(dá)到這個(gè)目的蜻展。

雖然nohup很容易使用喉誊,但還是比較“簡(jiǎn)陋”的,對(duì)于簡(jiǎn)單的命令能夠應(yīng)付過來纵顾,對(duì)于復(fù)雜的需要人機(jī)交互的任務(wù)就麻煩了伍茄。
其實(shí)我們可以使用一個(gè)更為強(qiáng)大的實(shí)用程序screen。流行的Linux發(fā)行版(例如Red Hat Enterprise Linux 4)通常會(huì)自帶screen實(shí)用程序施逾,如果沒有的話敷矫,可以從GNU screen的官方網(wǎng)站下載例获。

1)使用
執(zhí)行screen , 按任意鍵進(jìn)入子界面;
我用ping命令開始執(zhí)行,如果下班了曹仗,但是想關(guān)閉ssh以后ping繼續(xù)運(yùn)行榨汤,那么按ctrl+a 再按d 這樣暫停了子界面,會(huì)顯示[detached]的字樣怎茫,這時(shí)候 我回到了父界面收壕;
用screen –ls查看目前子界面的狀態(tài)screen -ls
There is a screen on: 22292.pts-3.free (Detached)
1 Socket in /tmp/screens/S-root,這里的22292其實(shí)是子界面的pid號(hào)轨蛤;

如果回到子界面 用screen –r 22292蜜宪,一下子彈到了ping 的子界面;

2)更多幫助
可以通過C-a(ctrl+a)?來查看所有的鍵綁定祥山,常用的鍵綁定有:

C-a ?
顯示所有鍵綁定信息
C-a w
顯示所有窗口列表
C-a C-a
切換到之前顯示的窗口
C-a c
創(chuàng)建一個(gè)新的運(yùn)行shell的窗口并切換到該窗口
C-a n
切換到下一個(gè)窗口
C-a p
切換到前一個(gè)窗口(與C-a n相對(duì))
C-a 0..9
切換到窗口0..9
C-a a
發(fā)送C-a到當(dāng)前窗口
C-a d
暫時(shí)斷開screen會(huì)話
C-a k
殺掉當(dāng)前窗口
C-a [
進(jìn)入拷貝/回滾模式

其他常用選項(xiàng):

-c file
使用配置文件file圃验,而不使用默認(rèn)的$HOME/.screenrc
-d|-D [pid.tty.host]
不開啟新的screen會(huì)話,而是斷開其他正在運(yùn)行的screen會(huì)話
-h num
指定歷史回滾緩沖區(qū)大小為num行
-list|-ls
列出現(xiàn)有screen會(huì)話枪蘑,格式為pid.tty.host
-d -m
啟動(dòng)一個(gè)開始就處于斷開模式的會(huì)話
-r sessionowner/ [pid.tty.host]
重新連接一個(gè)斷開的會(huì)話损谦。多用戶模式下連接到其他用戶screen會(huì)話需要指定sessionowner,需要setuid-root權(quán)限
-S sessionname
創(chuàng)建screen會(huì)話時(shí)為會(huì)話指定一個(gè)名字
-v
顯示screen版本信息
-wipe [match]
同-list岳颇,但刪掉那些無法連接的會(huì)話 [圖片上傳失敗...(image-6e5bb2-1567049022810)]

其他資料:

  1. Linux 技巧:讓進(jìn)程在后臺(tái)可靠運(yùn)行的幾種方法照捡,https://www.ibm.com/developerworks/cn/linux/l-cn-nohup/
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市话侧,隨后出現(xiàn)的幾起案子栗精,更是在濱河造成了極大的恐慌,老刑警劉巖瞻鹏,帶你破解...
    沈念sama閱讀 206,602評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件悲立,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡新博,警方通過查閱死者的電腦和手機(jī)薪夕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來赫悄,“玉大人原献,你說我怎么就攤上這事」』矗” “怎么了姑隅?”我有些...
    開封第一講書人閱讀 152,878評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)倔撞。 經(jīng)常有香客問我讲仰,道長(zhǎng),這世上最難降的妖魔是什么痪蝇? 我笑而不...
    開封第一講書人閱讀 55,306評(píng)論 1 279
  • 正文 為了忘掉前任鄙陡,我火速辦了婚禮冕房,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘趁矾。我一直安慰自己毒费,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評(píng)論 5 373
  • 文/花漫 我一把揭開白布愈魏。 她就那樣靜靜地躺著,像睡著了一般想际。 火紅的嫁衣襯著肌膚如雪培漏。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,071評(píng)論 1 285
  • 那天胡本,我揣著相機(jī)與錄音牌柄,去河邊找鬼。 笑死侧甫,一個(gè)胖子當(dāng)著我的面吹牛珊佣,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播披粟,決...
    沈念sama閱讀 38,382評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼咒锻,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了守屉?” 一聲冷哼從身側(cè)響起惑艇,我...
    開封第一講書人閱讀 37,006評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎拇泛,沒想到半個(gè)月后滨巴,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,512評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡俺叭,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,965評(píng)論 2 325
  • 正文 我和宋清朗相戀三年恭取,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片熄守。...
    茶點(diǎn)故事閱讀 38,094評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蜈垮,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出柠横,到底是詐尸還是另有隱情窃款,我是刑警寧澤,帶...
    沈念sama閱讀 33,732評(píng)論 4 323
  • 正文 年R本政府宣布牍氛,位于F島的核電站晨继,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏搬俊。R本人自食惡果不足惜紊扬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,283評(píng)論 3 307
  • 文/蒙蒙 一蜒茄、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧餐屎,春花似錦檀葛、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至藏鹊,卻和暖如春润讥,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背盘寡。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工楚殿, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人竿痰。 一個(gè)月前我還...
    沈念sama閱讀 45,536評(píng)論 2 354
  • 正文 我出身青樓脆粥,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親影涉。 傳聞我的和親對(duì)象是個(gè)殘疾皇子变隔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,828評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容