shell 作為一門 linux 下使用廣泛的系統(tǒng)語言,語法簡(jiǎn)單,上手容易,但是想要用好,少犯錯(cuò)誤,也不是那么容易的一件事,可謂雖是居家旅行之良藥,但也是殺人滅口之利器~
今天就來聊聊 linux 下一個(gè)常見的問題:如何避免誤刪目錄。下文會(huì)詳細(xì)的講述不同的場(chǎng)景下誤刪目錄,以及相應(yīng)的解決方案。
1、變量為空導(dǎo)致誤刪文件
base_path=/usr/sbin
tmp_file=`cmd_invalid`
# rm -rf $base_path/$tmp_file
這種情況下如果 cmd 執(zhí)行出錯(cuò)或者返回為空,后果將是災(zāi)難性的,那如何防范呢?
(1)利用 shell 的變量擴(kuò)展功能,如果變量為空賦給默認(rèn)值或者拋出異常退出腳本:
echo ${base_path:?var is empty}/${tmp_file:?var is empty}
-bash: tmp_file: var is empty
(2)人肉判斷變量是否為空:
[[ ${tmp_file} == "" ]] && echo 1
1[[ -z ${tmp_file} ]] && echo 1
1
(3)如果變量未定義還可以開啟 set 選項(xiàng):
# cat a.sh
set -u
b=
echo $b
echo $a
echo 1
# bash a.sh
a.sh: line 4: a: unbound variable
2、路徑含有空格導(dǎo)致誤刪文件
史上最經(jīng)典的要數(shù)下面這個(gè)bumblebee項(xiàng)目了,這個(gè)項(xiàng)目本來不出名,不過,程序在其安裝腳本install.sh里的一個(gè)bug讓這個(gè)項(xiàng)目一下子成了全世界最矚目的項(xiàng)目。
那我們?cè)撊绾畏婪哆@種問題呢?
(1)良好的編程習(xí)慣:變量加引號(hào)防止擴(kuò)展
path="/usr/local /sbin"
# rm -rf $path
rm -rf "$path"
(2)對(duì)變量進(jìn)行語義檢查
比如檢測(cè)是否含有空格等特殊字符,不通用,不推薦這么做
3、目錄或文件含有特殊字符導(dǎo)致誤刪文件
ll
總用量 8
drwxrwxr-x 2 work work 4096 11月 24 18:57 '~'
-rw-rw-r-- 1 work work 34 11月 24 19:49 a.sh
# rm -rf ~
那我們?cè)撊绾畏婪哆@種問題呢?
(1)良好的編程習(xí)慣:變量加引號(hào)防止擴(kuò)展
rm -rf "~"
(2)如果不確定,刪除之前 echo或 find一下,看變量被擴(kuò)展成啥了
echo rm -rf "~"
rm -rf ~
echo rm -rf ~
rm -rf /home/work
4、cd 切換目錄失敗,導(dǎo)致文件被誤刪
cd ooxx_path_not_exsit
rm -rf *.exe
恭喜這種情況下你的當(dāng)前目錄下匹配文件都會(huì)被誤刪,那我們?cè)撊绾畏婪哆@種問題呢?
(1)使用邏輯短路操作
cd path && rm -rf *.exe
(2)檢測(cè) path 是否存在
[[ -d ~ ]] && echo 1
1
5、終極解決方案
不要使用 root 操作系統(tǒng)資源,這樣至少不會(huì)刪除系統(tǒng)文件。
6、在登錄 shell 下使用友好的提示符
友好的命令提示符能時(shí)刻提醒操作者當(dāng)前在哪個(gè)路徑下,避免錯(cuò)誤的路徑下操作文件。
上文到此就結(jié)束了,列舉了一些常見的case和解決方案,希望能對(duì)大家有所啟發(fā)。
最后我們來說說刪庫(kù)跑路的事兒:
IT界的一個(gè)老梗,一次某論壇的數(shù)據(jù)庫(kù)管理員抱怨自己老板一直虐待他,結(jié)果他一氣之下就刪庫(kù)跑路了……于是就有了從刪庫(kù)到跑路這個(gè)梗......
當(dāng)刪庫(kù)成為一種時(shí)尚
6月初,位于荷蘭海牙的一家云主機(jī)商verelox.com,一名前任管理員刪光了該公司所有客戶的數(shù)據(jù),并且擦除了大多數(shù)服務(wù)器上面的內(nèi)容,帶來了巨大的損失。
2017-04-05,位于紐約的云服務(wù)商 Digital Ocean 遭遇了一次長(zhǎng)達(dá)4小時(shí)56分鐘的停機(jī)事故,事故的原因是主數(shù)據(jù)庫(kù)被刪除了(primary database had been deleted),由于配置錯(cuò)誤,本應(yīng)指向測(cè)試環(huán)境的任務(wù)被指向了生產(chǎn)環(huán)境,測(cè)試任務(wù)包含的環(huán)境初始化過程刪除了主生產(chǎn)數(shù)據(jù)庫(kù)。(不以規(guī)矩不成方圓:Digital Ocean也刪除了他們的數(shù)據(jù)庫(kù))
2月11日,網(wǎng)絡(luò)剪報(bào)服務(wù)商 -Instapaper 遭受了超過31小時(shí)的服務(wù)中斷,聲明需要一個(gè)星期的數(shù)據(jù)庫(kù)恢復(fù)時(shí)間,然而經(jīng)過10天的恢復(fù),也僅僅恢復(fù)了6個(gè)星期的數(shù)據(jù)。(云服務(wù)真的靠譜嗎? AWS 用戶中斷31小時(shí)僅恢復(fù)6周數(shù)據(jù))
2月1日,除夕剛剛過完,荷蘭的一個(gè)DBA在數(shù)據(jù)庫(kù)復(fù)制過程中意外地刪除了一個(gè)錯(cuò)誤的服務(wù)器上的目錄,刪除了一個(gè)包含300GB的實(shí)時(shí)生產(chǎn)數(shù)據(jù)的文件夾。300G的數(shù)據(jù)庫(kù)被刪成4.5G,由于沒有有效的備份,嘗試了所有5個(gè)恢復(fù)工具都沒有完成恢復(fù)。在丟失數(shù)據(jù)并恢復(fù)失敗后,服務(wù)器徹底崩潰。五重備份無一有效,還有哪些 rm -rf 和GitLab類似的憂傷?
1月20日,大約一定是受到川普上任的影響,突如其來的服務(wù)器故障影響了一大批爐石玩家,恢復(fù)時(shí)間長(zhǎng),由于意外斷電,導(dǎo)致數(shù)據(jù)庫(kù)損壞,不得不通過游戲回檔恢復(fù)數(shù)據(jù)庫(kù)的使用。
而若操作者具有較高級(jí)別的權(quán)限,數(shù)據(jù)庫(kù)面臨的災(zāi)難則是巨大的。Lucchese前IT主管,在離職的時(shí)候收集了IT部門所有職工的用戶名和密碼然后偽裝成一臺(tái)辦公室打印機(jī)創(chuàng)建了一個(gè)密碼賬號(hào),并在其辦公室內(nèi)使用該賬號(hào)進(jìn)行了一系列的違規(guī)操作,給企業(yè)帶來了嚴(yán)重的損失。Venzor后來被捕,并面臨最高達(dá)10年的監(jiān)禁生活以及25萬美元的罰款。
在剛剛過去的7月,花旗銀行的前員工倫農(nóng)·雷·布朗,通過非法執(zhí)行命令,刪除了花旗銀行的內(nèi)部網(wǎng)絡(luò)上10只核心路由器上的配置文件。結(jié)果引起的故障導(dǎo)致全國(guó)110個(gè)分行無法正常使用網(wǎng)絡(luò)和電話系統(tǒng),占到花旗銀行所有分支機(jī)構(gòu)總數(shù)的約90%。
手動(dòng)刪庫(kù)簡(jiǎn)直太low,我都是腳本自動(dòng)刪
又不禁想起了Google曾經(jīng)轟動(dòng)一時(shí)的流水線刪庫(kù)事件,這可是團(tuán)隊(duì)作案喲,這么團(tuán)結(jié)真的好嗎?(時(shí)移世易:遵從既往經(jīng)驗(yàn)致 1.5PB 數(shù)據(jù)刪除,Google SRE是如何應(yīng)對(duì)的?)
一個(gè) Google Music 用戶匯報(bào)某些之前播放正常的歌曲現(xiàn)在無法播放了。Google Music 的用戶支持團(tuán)隊(duì)通知了工程師團(tuán)隊(duì),這個(gè)問題被歸類為流媒體播放問題進(jìn)行調(diào)查。3 月 7 日,負(fù)責(zé)調(diào)查此事的工程師發(fā)現(xiàn)無法播放的歌曲的元數(shù)據(jù)中缺少了一個(gè)針對(duì)具體音頻數(shù)據(jù)文件的指針,于是他就修復(fù)了這個(gè)歌曲的問題。
但是,Google 工程師經(jīng)常喜歡深究問題,也引以為豪,于是他就繼續(xù)在系統(tǒng)中查找可能存在的問題,當(dāng)發(fā)現(xiàn)數(shù)據(jù)完整性損壞的真正原因時(shí),他卻差點(diǎn)嚇出心臟病:這段數(shù)據(jù)是被某個(gè)保護(hù)隱私目的的數(shù)據(jù)刪除流水線所刪掉的。Google Music 的這個(gè)子系統(tǒng)的設(shè)計(jì)目標(biāo)之一就是在盡可能短的時(shí)間內(nèi)刪除海量音頻數(shù)據(jù)。
該流水線任務(wù)大概誤刪除了 60 萬條音頻文件,大概影響了 2.1 萬用戶.
沒有刪過庫(kù)的Linux管理員,不是好的Linux運(yùn)維工程師!
-
Linux
+關(guān)注
關(guān)注
88文章
11758瀏覽量
219009 -
運(yùn)維工程師
+關(guān)注
關(guān)注
4文章
39瀏覽量
8475
原文標(biāo)題:Linux Shell從入門到刪除根目錄跑路指南
文章出處:【微信號(hào):magedu-Linux,微信公眾號(hào):馬哥Linux運(yùn)維】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
電子工程師的雙標(biāo)瞬間 #電子 #電子愛好者 #電子工程師 #揚(yáng)興科技 #雙標(biāo)
AIOps 智能化運(yùn)維:讓 IT 運(yùn)維從 “被動(dòng)救火” 到 “主動(dòng)防御”
什么是BSP工程師
想成為硬件工程師?我教你啊!你得先學(xué)會(huì)這些...... #硬件工程師 #電子工程師 #電子愛好者 #電子行業(yè)
學(xué)習(xí)Linux應(yīng)該從哪里開始?
硬件工程師面試必會(huì):10個(gè)核心考點(diǎn)#硬件設(shè)計(jì) #硬件工程師 #電路設(shè)計(jì) #電路設(shè)計(jì)
一文掌握Linux命令
Linux網(wǎng)絡(luò)管理的關(guān)鍵技術(shù)和最佳實(shí)踐
硬件工程師看了只會(huì)找個(gè)角落默默哭泣#硬件工程師 #MDD #MDD辰達(dá)半導(dǎo)體 #產(chǎn)品經(jīng)理 #軟件工程師
物聯(lián)網(wǎng)工程師為什么要學(xué)Linux?
一個(gè)優(yōu)秀的射頻測(cè)試工程師需要具備哪些技能?
做最優(yōu)秀的Linux運(yùn)維工程師,從刪庫(kù)開始!
評(píng)論