0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

做最優(yōu)秀的Linux運維工程師,從刪庫開始!

馬哥Linux運維 ? 來源:YXQ ? 2019-06-05 17:44 ? 次閱讀

shell 作為一門 linux 下使用廣泛的系統(tǒng)語言,語法簡單,上手容易,但是想要用好,少犯錯誤,也不是那么容易的一件事,可謂雖是居家旅行之良藥,但也是殺人滅口之利器~

今天就來聊聊 linux 下一個常見的問題:如何避免誤刪目錄。下文會詳細的講述不同的場景下誤刪目錄,以及相應(yīng)的解決方案。

1、變量為空導(dǎo)致誤刪文件

base_path=/usr/sbin

tmp_file=`cmd_invalid`

# rm -rf $base_path/$tmp_file

這種情況下如果 cmd 執(zhí)行出錯或者返回為空,后果將是災(zāi)難性的,那如何防范呢?

(1)利用 shell 的變量擴展功能,如果變量為空賦給默認值或者拋出異常退出腳本:

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 選項

# 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ù)下面這個bumblebee項目了,這個項目本來不出名,不過,程序在其安裝腳本install.sh里的一個bug讓這個項目一下子成了全世界最矚目的項目。

那我們該如何防范這種問題呢?

(1)良好的編程習(xí)慣:變量加引號防止擴展

path="/usr/local /sbin"

# rm -rf $path

rm -rf "$path"

(2)對變量進行語義檢查

比如檢測是否含有空格等特殊字符,不通用,不推薦這么做

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 ~

那我們該如何防范這種問題呢?

(1)良好的編程習(xí)慣:變量加引號防止擴展

rm -rf "~"

(2)如果不確定,刪除之前 echo或 find一下,看變量被擴展成啥了

echo rm -rf "~"

rm -rf ~

echo rm -rf ~

rm -rf /home/work

4、cd 切換目錄失敗,導(dǎo)致文件被誤刪

cd ooxx_path_not_exsit

rm -rf *.exe

恭喜這種情況下你的當前目錄下匹配文件都會被誤刪,那我們該如何防范這種問題呢?

(1)使用邏輯短路操作

cd path && rm -rf *.exe

(2)檢測 path 是否存在

[[ -d ~ ]] && echo 1

1

5、終極解決方案

不要使用 root 操作系統(tǒng)資源,這樣至少不會刪除系統(tǒng)文件。

6、在登錄 shell 下使用友好的提示符

友好的命令提示符能時刻提醒操作者當前在哪個路徑下,避免錯誤的路徑下操作文件。

上文到此就結(jié)束了,列舉了一些常見的case和解決方案,希望能對大家有所啟發(fā)。

最后我們來說說刪庫跑路的事兒:

IT界的一個老梗,一次某論壇的數(shù)據(jù)庫管理員抱怨自己老板一直虐待他,結(jié)果他一氣之下就刪庫跑路了……于是就有了從刪庫到跑路這個梗......

當刪庫成為一種時尚

6月初,位于荷蘭海牙的一家云主機商verelox.com,一名前任管理員刪光了該公司所有客戶的數(shù)據(jù),并且擦除了大多數(shù)服務(wù)器上面的內(nèi)容,帶來了巨大的損失。

2017-04-05,位于紐約的云服務(wù)商 Digital Ocean 遭遇了一次長達4小時56分鐘的停機事故,事故的原因是主數(shù)據(jù)庫被刪除了(primary database had been deleted),由于配置錯誤,本應(yīng)指向測試環(huán)境的任務(wù)被指向了生產(chǎn)環(huán)境,測試任務(wù)包含的環(huán)境初始化過程刪除了主生產(chǎn)數(shù)據(jù)庫。(不以規(guī)矩不成方圓:Digital Ocean也刪除了他們的數(shù)據(jù)庫)

2月11日,網(wǎng)絡(luò)剪報服務(wù)商 -Instapaper 遭受了超過31小時的服務(wù)中斷,聲明需要一個星期的數(shù)據(jù)庫恢復(fù)時間,然而經(jīng)過10天的恢復(fù),也僅僅恢復(fù)了6個星期的數(shù)據(jù)。(云服務(wù)真的靠譜嗎? AWS 用戶中斷31小時僅恢復(fù)6周數(shù)據(jù))

2月1日,除夕剛剛過完,荷蘭的一個DBA在數(shù)據(jù)庫復(fù)制過程中意外地刪除了一個錯誤的服務(wù)器上的目錄,刪除了一個包含300GB的實時生產(chǎn)數(shù)據(jù)的文件夾。300G的數(shù)據(jù)庫被刪成4.5G,由于沒有有效的備份,嘗試了所有5個恢復(fù)工具都沒有完成恢復(fù)。在丟失數(shù)據(jù)并恢復(fù)失敗后,服務(wù)器徹底崩潰。五重備份無一有效,還有哪些 rm -rf 和GitLab類似的憂傷?

1月20日,大約一定是受到川普上任的影響,突如其來的服務(wù)器故障影響了一大批爐石玩家,恢復(fù)時間長,由于意外斷電,導(dǎo)致數(shù)據(jù)庫損壞,不得不通過游戲回檔恢復(fù)數(shù)據(jù)庫的使用。

而若操作者具有較高級別的權(quán)限,數(shù)據(jù)庫面臨的災(zāi)難則是巨大的。Lucchese前IT主管,在離職的時候收集了IT部門所有職工的用戶名和密碼然后偽裝成一臺辦公室打印機創(chuàng)建了一個密碼賬號,并在其辦公室內(nèi)使用該賬號進行了一系列的違規(guī)操作,給企業(yè)帶來了嚴重的損失。Venzor后來被捕,并面臨最高達10年的監(jiān)禁生活以及25萬美元的罰款。

在剛剛過去的7月,花旗銀行的前員工倫農(nóng)·雷·布朗,通過非法執(zhí)行命令,刪除了花旗銀行的內(nèi)部網(wǎng)絡(luò)上10只核心路由器上的配置文件。結(jié)果引起的故障導(dǎo)致全國110個分行無法正常使用網(wǎng)絡(luò)和電話系統(tǒng),占到花旗銀行所有分支機構(gòu)總數(shù)的約90%。

手動刪庫簡直太low,我都是腳本自動刪

又不禁想起了Google曾經(jīng)轟動一時的流水線刪庫事件,這可是團隊作案喲,這么團結(jié)真的好嗎?(時移世易:遵從既往經(jīng)驗致 1.5PB 數(shù)據(jù)刪除,Google SRE是如何應(yīng)對的?)

一個 Google Music 用戶匯報某些之前播放正常的歌曲現(xiàn)在無法播放了。Google Music 的用戶支持團隊通知了工程師團隊,這個問題被歸類為流媒體播放問題進行調(diào)查。3 月 7 日,負責調(diào)查此事的工程師發(fā)現(xiàn)無法播放的歌曲的元數(shù)據(jù)中缺少了一個針對具體音頻數(shù)據(jù)文件的指針,于是他就修復(fù)了這個歌曲的問題。

但是,Google 工程師經(jīng)常喜歡深究問題,也引以為豪,于是他就繼續(xù)在系統(tǒng)中查找可能存在的問題,當發(fā)現(xiàn)數(shù)據(jù)完整性損壞的真正原因時,他卻差點嚇出心臟病:這段數(shù)據(jù)是被某個保護隱私目的的數(shù)據(jù)刪除流水線所刪掉的。Google Music 的這個子系統(tǒng)的設(shè)計目標之一就是在盡可能短的時間內(nèi)刪除海量音頻數(shù)據(jù)。

該流水線任務(wù)大概誤刪除了 60 萬條音頻文件,大概影響了 2.1 萬用戶.

沒有刪過庫的Linux管理員,不是好的Linux運維工程師!

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11123

    瀏覽量

    207908
  • 運維工程師
    +關(guān)注

    關(guān)注

    4

    文章

    39

    瀏覽量

    8239

原文標題:Linux Shell從入門到刪除根目錄跑路指南

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    正是拼的年紀|65歲電子工程師上班VLOG #65歲退休 #電子工程師 #搞笑 #上班vlog

    電子工程師
    安泰小課堂
    發(fā)布于 :2024年07月25日 11:31:02

    硬件工程師如何元器件變更的決策

    硬件工程師如何元器件變更的決策某產(chǎn)品在從研發(fā)轉(zhuǎn)規(guī)模生產(chǎn)階段,采購部門給硬件工程師推薦了新的MOSFET(稱為A),該物料比該產(chǎn)品研發(fā)階段使用的MOSFET(稱為B)價格更低,且供貨渠道更友好。作為
    的頭像 發(fā)表于 07-06 08:17 ?266次閱讀
    硬件<b class='flag-5'>工程師</b>如何<b class='flag-5'>做</b>元器件變更的決策

    大廠電子工程師常見面試題#電子工程師 #硬件工程師 #電路知識 #面試題

    電子工程師電路
    安泰小課堂
    發(fā)布于 :2024年04月30日 17:33:15

    管理平臺:基礎(chǔ)到智能的飛躍

    管理平臺為企業(yè)提供了基礎(chǔ)到智能
    的頭像 發(fā)表于 04-16 16:26 ?295次閱讀

    如何入門硬件工程師

    想跨行業(yè)硬件設(shè)計工程師,應(yīng)該如何學(xué)習(xí)規(guī)劃呢
    發(fā)表于 03-17 21:49

    優(yōu)秀電源工程師需要哪些必備技能?

    隨著電源市場的不斷擴張,開關(guān)電源行業(yè)飛速發(fā)展,企業(yè)對電源工程師的需求日益增加,對電源工程師的技能要求也日漸提高,相信沒有一位電源工程師會錯過讓自己變得更優(yōu)秀的機會。作為一名數(shù)字電源從業(yè)
    發(fā)表于 01-29 11:29

    【2023電子工程師大會】單片機/RTOS/Linux全棧工程師

    【2023電子工程師大會】單片機/RTOS/Linux全棧工程師修煉之路ppt
    發(fā)表于 01-03 16:31 ?39次下載

    優(yōu)秀電源工程師的必備技能大揭秘!

    隨著電源市場的不斷擴張,開關(guān)電源行業(yè)飛速發(fā)展,企業(yè)對電源工程師的需求日益增加,對電源工程師的技能要求也日漸提高,相信沒有一位電源工程師會錯過讓自己變得更優(yōu)秀的機會。作為一名數(shù)字電源從業(yè)
    的頭像 發(fā)表于 12-19 08:23 ?1475次閱讀
    <b class='flag-5'>優(yōu)秀</b>電源<b class='flag-5'>工程師</b>的必備技能大揭秘!

    FPGA工程師需要具備哪些技能?

    各種通信協(xié)議的概念、協(xié)作流程、幀結(jié)構(gòu)等。常見的通信協(xié)議包括UART、SPI、I2C、USB、PCIe、以太網(wǎng)等。 FPGA工程師還需要了解如何使用各種協(xié)議的開源和硬件IP核,這些可以在互聯(lián)網(wǎng)
    發(fā)表于 11-09 11:03

    如何成為一名優(yōu)秀的嵌入式工程師?

    如何成為一名優(yōu)秀的嵌入式工程師?嵌入式學(xué)習(xí)的第一步,首先是C語言。 1.理解內(nèi)存管理:C語言不同于高級語言,它不會自動管理內(nèi)存。因此,你需要理解并掌握如何使用malloc()、free()等函數(shù)
    發(fā)表于 11-07 15:36

    如何應(yīng)用Python解決5個常見問題?

    解析日志文件并提取有用信息是工程師經(jīng)常要進行的任務(wù)之一。使用 Python 腳本可以方便地實現(xiàn)這一操作。 在 Python 中,可以使用第三方 regex 來解析日志文件。reg
    發(fā)表于 11-02 10:06 ?247次閱讀

    【社區(qū)之星】彭仲:扎實的基本功與時間的沉淀才是工程師成功的關(guān)鍵!

    入了電子行業(yè)。 社區(qū)小助手:作為一名從業(yè)多年的工程師,能否分享你的工作經(jīng)歷和一些比較成功的工程項目或優(yōu)秀作品?開發(fā)這個產(chǎn)品的整個過程,有什么記憶深刻的經(jīng)歷嗎? 彭仲老師: 一體式胎心
    發(fā)表于 10-13 14:15