導(dǎo)入大批量的數(shù)據(jù),在阿里云服務(wù)器上寫(xiě)了一個(gè)shell腳本來(lái)執(zhí)行,本人MAC終端連接服務(wù)器,但是突然公司斷網(wǎng)了。我在終端看到shell腳本終止了,輸出了結(jié)束標(biāo)識(shí)符。但是本人不知道腳本再斷網(wǎng)之前就結(jié)束了還是斷網(wǎng)的時(shí)候結(jié)束的???而且,斷網(wǎng)對(duì)腳本運(yùn)行有影響嗎?
TD;TR: 多年Linux服務(wù)器運(yùn)維經(jīng)驗(yàn)的老司機(jī)告訴你,會(huì)有影響,所以長(zhǎng)時(shí)間運(yùn)行并且不允許中斷的腳本你應(yīng)該放在screen/tmux這一類(lèi)虛擬終端執(zhí)行,幫你hold住session不中斷。
但并不意味著ssh斷開(kāi)你運(yùn)行的腳本一定會(huì)崩潰,我們假定你的腳本通常都是單線程同步運(yùn)行的命令行
#!/bin/bash -e
command1
command2
command3
那么在Linux上用ps -efx命令看你的進(jìn)程樹(shù)大致是這個(gè)樣子的:
sshd
\_ -bash
\_ bash -e /path/to/your_script.sh
\_ command1
如果此時(shí)強(qiáng)行斷開(kāi)ssh連接(比如你強(qiáng)行關(guān)閉終端窗口,或者網(wǎng)絡(luò)斷開(kāi)),那么你的ssh通道會(huì)broken pipe,于是系統(tǒng)會(huì)收到SIGHUP信號(hào),干掉你的sshd fork出來(lái)的bash進(jìn)程。于是你的command1就變成孤兒進(jìn)程了。這個(gè)套路是不是有點(diǎn)眼熟?沒(méi)錯(cuò)就是殺死僵尸進(jìn)程的方法,那么command1將會(huì)被init進(jìn)程(pid為1的進(jìn)程)托管。如果你的子進(jìn)程開(kāi)啟了NOSIGHUP,是不會(huì)被SIGHUP信號(hào)干掉的,直接變成init進(jìn)程的子進(jìn)程繼續(xù)運(yùn)行。所以此時(shí)你再次登錄ssh會(huì)發(fā)現(xiàn)command1已經(jīng)變成了init的子進(jìn)程,像這樣:
init
\_ command1
如果你的command1沒(méi)有開(kāi)啟NO_SIGHUP,那么是不會(huì)看到這個(gè)情況的,bash被干掉,下面的command1也將被干掉,并且不會(huì)再執(zhí)行command2,command3
當(dāng)然session已經(jīng)丟失,你也無(wú)法看到command1的stdout和stderr了。這時(shí)候你發(fā)現(xiàn)由于bash已經(jīng)被干掉,所以在command1執(zhí)行完畢之后,command2;command3自然無(wú)法執(zhí)行了。這就可能會(huì)對(duì)你的邏輯造成比較嚴(yán)重的影響——你的腳本執(zhí)行步驟并未完成,并且如果你的腳本不是冪等,也將難以重試或繼續(xù)。
因此,對(duì)于長(zhǎng)時(shí)間運(yùn)行并且不允許中斷的腳本,你應(yīng)該使用screen/tmux托管。
另:不一定所有的進(jìn)程都會(huì)默認(rèn)開(kāi)啟忽略SIGHUP信號(hào),因此大多數(shù)進(jìn)程對(duì)于SIGHUP信號(hào)的響應(yīng)是直接退出
北大青鳥(niǎo)APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專(zhuān)業(yè)的國(guó)家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
北大課工場(chǎng)是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國(guó)家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國(guó)制造2025”,實(shí)現(xiàn)中華民族偉大復(fù)興的升級(jí)產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國(guó)職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開(kāi)發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_(kāi)發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開(kāi)發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開(kāi)發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開(kāi)發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。