歡迎光臨
每天分享高質量文章

精通Linux常用的100+命令大全萬字詳解長文(珍藏版)

運維行業正在變革?推薦閱讀:30萬年薪Linux運維工程師成長魔法


Linux提供了大量的命令,利用它可以有效地完成大量的工作,如磁盤操作、檔案存取、目錄操作、行程管理、檔案權限設定等。所以,在Linux系統上工作離不開使用系統提供的命令。要想真正理解Linux系統,就必須從Linux命令學起,通過基礎的命令學習可以進一步理解Linux系統。

不同Linux發行版的命令數量不一樣,但Linux發行版本最少的命令也有200多個。這裡馬哥linux學院學習小組把比較重要和使用頻率最多的命令,按照它們在系統中的作用分成下麵六個部分一一介紹。

◆ 安裝和登錄命令:login、shutdown、halt、reboot、install、mount、umount、chsh、exit、last;

◆ 檔案處理命令:file、mkdir、grep、dd、find、mv、ls、diff、cat、ln;

◆ 系統管理相關命令:df、top、free、quota、at、lp、adduser、groupadd、kill、crontab;

◆ 網絡操作命令:ifconfig、ip、ping、netstat、telnet、ftp、route、rlogin、rcp、finger、mail、 nslookup;

◆ 系統安全相關命令:passwd、su、umask、chgrp、chmod、chown、chattr、sudo ps、who;

◆ 其它命令:tar、unzip、gunzip、unarj、mtools、man、unendcode、uudecode。

本文以Mandrake Linux 9.1(Kenrel 2.4.21)為例,介紹Linux下的安裝和登錄命令。

immortality按:請用ctrl+f在本頁中查找某一部分的內容或某一命令的用法。


Linux必學的60個命令(1)-安裝與登陸命令

login

1.作用

login的作用是登錄系統,它的使用權限是所有用戶。

2.格式

login [name][-p ][-h 主機名稱]

3.主要引數

-p:通知login保持現在的環境引數。

-h:用來向遠程登錄的之間傳輸用戶名。

如果選擇用命令列樣式登錄Linux的話,那麼看到的第一個Linux命令就是login:。

一般界面是這樣的:

Manddrake Linux release 9.1(Bamboo) for i586
renrel 2.4.21-0.13mdk on i686 / tty1
localhost login:root
password:

上面代碼中,第一行是Linux發行版本號,第二行是內核版本號和登錄的虛擬控制台,我們在第三行輸入登錄名,按“Enter”鍵在Password後輸入賬戶密碼,即可登錄系統。出於安全考慮,輸入賬戶密碼時字符不會在屏幕上回顯,光標也不移動。

登錄後會看到下麵這個界面(以超級用戶為例):

[[email protected] root]#
last login:Tue ,Nov 18 10:00:55 on vc/1

上面顯示的是登錄星期、月、日、時間和使用的虛擬控制台。

4.應用技巧

Linux是一個真正的多用戶操作系統,可以同時接受多個用戶登錄,還允許一個用戶進行多次登錄。這是因為Linux和許多版本的Unix一樣,提供了虛擬控制台的訪問方式,允許用戶在同一時間從控制台(系統的控制台是與系統直接相連的監視器和鍵盤)進行多次登錄。每個虛擬控制台可以看作是一個獨立的工作站,工作台之間可以切換。虛擬控制台的切換可以通過按下Alt鍵和一個功能鍵來實現,通常使用F1-F6 。

例如,用戶登錄後,按一下“Alt+F2”鍵,用戶就可以看到上面出現的“login:”提示符,說明用戶看到了第二個虛擬控制台。然後只需按“Alt+ F1”鍵,就可以回到第一個虛擬控制台。一個新安裝的Linux系統允許用戶使用“Alt+F1”到“Alt+F6”鍵來訪問前六個虛擬控制台。虛擬控制台最有用的是,當一個程式出錯造成系統死鎖時,可以切換到其它虛擬控制台工作,關閉這個程式。

shutdown

1.作用

shutdown命令的作用是關閉計算機,它的使用權限是超級用戶。

2.格式

shutdown [-h][-i][-k][-m][-t]

3.重要引數

-t:在改變到其它運行級別之前,告訴init程式多久以後關機。

-k:並不真正關機,只是送警告信號給每位登錄者。

-h:關機後關閉電源。

-c:cancel current process取消目前正在執行的關機程式。所以這個選項當然沒有時間引數,但是可以輸入一個用來解釋的訊息,而這信息將會送到每位使用者。

-F:在重啟計算機時強迫fsck。

-time:設定關機前的時間。

-m: 將系統改為單用戶樣式。

-i:關機時顯示系統信息。

4.命令說明

shutdown命令可以安全地將系統關機。有些用戶會使用直接斷掉電源的方式來關閉Linux系統,這是十分危險的。因為Linux與Windows不同,其後臺運行著許多行程,所以強制關機可能會導致行程的資料丟失,使系統處於不穩定的狀態,甚至在有的系統中會損壞硬體設備(硬碟)。在系統關機前使用 shutdown命令,系統管理員會通知所有登錄的用戶系統將要關閉,並且login指令會被凍結,即新的用戶不能再登錄。

halt

1.作用

halt命令的作用是關閉系統,它的使用權限是超級用戶。

2.格式

halt [-n] [-w] [-d] [-f] [-i] [-p]

3.主要引數說明

-n:防止sync系統呼叫,它用在用fsck修補根分割槽之後,以阻止內核用老版本的超級塊改寫修補過的超級塊。

-w:並不是真正的重啟或關機,只是寫wtmp(/var/log/wtmp)紀錄。

-f:沒有呼叫shutdown,而強制關機或重啟。

-i:關機(或重啟)前,關掉所有的網絡接口。

-f:強迫關機,不呼叫shutdown這個指令。

-p: 當關機的時候順便做關閉電源的動作。

-d:關閉系統,但不留下紀錄。 

4.命令說明

halt就是呼叫shutdown -h。halt執行時,殺死應用行程,執行sync(將存於buffer中的資料強制寫入硬碟中)系統呼叫,檔案系統寫操作完成後就會停止內核。若系統的運行級別為0或6,則關閉系統;否則以shutdown指令(加上-h引數)來取代。 

reboot

1.作用

reboot命令的作用是重新啟動計算機,它的使用權限是系統管理者。

2.格式

reboot [-n] [-w] [-d] [-f] [-i]

3.主要引數

-n: 在重開機前不做將記憶體資料寫回硬碟的動作。

-w: 並不會真的重開機,只是把記錄寫到/var/log/wtmp檔案里。

-d: 不把記錄寫到/var/log/wtmp檔案里(-n這個引數包含了-d)。

-i: 在重開機之前先把所有與網絡相關的裝置停止。

install

1.作用

install命令的作用是安裝或升級軟體或備份資料,它的使用權限是所有用戶。

2.格式

(1)install [選項]… 來源 目的地

(2)install [選項]… 來源… 目錄

(3)install -d [選項]… 目錄…

在前兩種格式中,會將複製至或將多個檔案複製至已存在的,同時設定權限樣式及所有者/所屬組。在第三種格式中,會創建所有指定的目錄及它們的主目錄。長選項必須用的引數在使用短選項時也是必須的。

3.主要引數

--backup[=CONTROL]:為每個已存在的目的地檔案進行備份。

-b:類似 --backup,但不接受任何引數。

-c:(此選項不作處理)。

-d,--directory:所有引數都作為目錄處理,而且會創建指定目錄的所有主目錄。

-D:創建前的所有主目錄,然後將複製至 ;在第一種使用格式中有用。

-g,--group=組:自行設定所屬組,而不是行程目前的所屬組。

-m,--mode=樣式:自行設定權限樣式 (像chmod),而不是rwxr-xr-x。

-o,--owner=所有者:自行設定所有者 (只適用於超級用戶)。

-p,--preserve-timestamps:以檔案的訪問/修改時間作為相應的目的地檔案的時間屬性。

-s,--strip:用strip命令刪除symbol table,只適用於第一及第二種使用格式。

-S,--suffix=後綴:自行指定備份檔案的。

-v,--verbose:處理每個檔案/目錄時印出名稱。

--help:顯示此幫助信息並離開。

--version:顯示版本信息並離開。

mount

1.作用

mount命令的作用是加載檔案系統,它的用權限是超級用戶或/etc/fstab中允許的使用者。

2.格式

mount -a [-fv] [-t vfstype] [-n] [-rw] [-F] device dir

3.主要引數

-h:顯示輔助信息。

-v:顯示信息,通常和-f用來除錯。

-a:將/etc/fstab中定義的所有檔案系統掛上。

-F:這個命令通常和-a一起使用,它會為每一個mount的動作產生一個行程負責執行。在系統需要掛上大量NFS檔案系統時可以加快加載的速度。

-f:通常用於除錯。它會使mount不執行實際掛上的動作,而是模擬整個掛上的過程,通常會和-v一起使用。

-t vfstype:顯示被加載檔案系統的型別。

-n:一般而言,mount掛上後會在/etc/mtab中寫入一筆資料,在系統中沒有可寫入檔案系統的情況下,可以用這個選項取消這個動作。

4.應用技巧

在Linux和Unix系統上,所有檔案都是作為一個大型樹(以/為根)的一部分訪問的。要訪問CD-ROM上的檔案,需要將CD-ROM設備掛裝在檔案樹中的某個掛裝點。如果發行版安裝了自動掛裝包,那麼這個步驟可自動進行。在Linux中,如果要使用硬碟、光驅等儲存設備,就得先將它加載,當儲存設備掛上了之後,就可以把它當成一個目錄來訪問。掛上一個設備使用mount命令。在使用mount這個指令時,至少要先知道下列三種信息:要加載物件的檔案系統型別、要加載物件的設備名稱及要將設備加載到哪個目錄下。

(1)Linux可以識別的檔案系統

◆ Windows 95/98常用的FAT 32檔案系統:vfat ;

◆ Win NT/2000 的檔案系統:ntfs ;

◆ OS/2用的檔案系統:hpfs;

◆ Linux用的檔案系統:ext2、ext3;

◆ CD-ROM光盤用的檔案系統:iso9660。

雖然vfat是指FAT 32系統,但事實上它也兼容FAT 16的檔案系統型別。

(2)確定設備的名稱

在Linux中,設備名稱通常都存在/dev里。這些設備名稱的命名都是有規則的,可以用“推理”的方式把設備名稱找出來。例如,/dev/hda1這個 IDE設備,hd是Hard Disk(硬碟)的,sd是SCSI Device,fd是Floppy Device(或是Floppy Disk?)。a代表第一個設備,通常IDE接口可以接上4個IDE設備(比如4塊硬碟)。所以要識別IDE硬碟的方法分別就是hda、hdb、hdc、 hdd。hda1中的“1”代表hda的第一個硬碟分割槽 (partition),hda2代表hda的第二主分割槽,第一個邏輯分割槽從hda5開始,依此類推。此外,可以直接檢查/var/log/messages檔案,在該檔案中可以找到計算機開機後系統已辨認出來的設備代號。

(3)查找掛接點

在決定將設備掛接之前,先要查看一下計算機是不是有個/mnt的空目錄,該目錄就是專門用來當作掛載點(Mount Point)的目錄。建議在/mnt里建幾個/mnt/cdrom、/mnt/floppy、/mnt/mo等目錄,當作目錄的專用掛載點。舉例而言,如要掛載下列5個設備,其執行指令可能如下 (假設都是Linux的ext2系統,如果是Windows XX請將ext2改成vfat):

軟盤 ===>mount -t ext2 /dev/fd0 /mnt/floppy
cdrom ===>mount -t iso9660 /dev/hdc /mnt/cdrom
SCSI cdrom ===>mount -t iso9660 /dev/sdb /mnt/scdrom
SCSI cdr ===>mount -t iso9660 /dev/sdc /mnt/scdr

不過目前大多數較新的Linux發行版本(包括紅旗 Linux、中軟Linux、Mandrake Linux等)都可以自動掛裝檔案系統,但Red Hat Linux除外。

umount

1.作用

umount命令的作用是卸載一個檔案系統,它的使用權限是超級用戶或/etc/fstab中允許的使用者。

2.格式

unmount -a [-fFnrsvw] [-t vfstype] [-n] [-rw] [-F] device dir

3.使用說明

umount命令是mount命令的逆操作,它的引數和使用方法和mount命令是一樣的。Linux掛裝CD-ROM後,會鎖定CD—ROM,這樣就不能用CD-ROM面板上的Eject按鈕彈出它。但是,當不再需要光盤時,如果已將/cdrom作為符號鏈接,請使用umount/cdrom來卸裝它。僅當無用戶正在使用光盤時,該命令才會成功。該命令包括了將帶有當前工作目錄當作該光盤中的目錄的終端視窗。

chsh

1.作用

chsh命令的作用是更改使用者shell設定,它的使用權限是所有使用者。

2.格式

chsh [ -s ] [ -list] [ --help ] [ -v ] [ username ]

3.主要引數

-l:顯示系統所有Shell型別。

-v:顯示Shell版本號。

4.應用技巧

前面介紹了Linux下有多種Shell,一般預設的是Bash,如果想更換Shell型別可以使用chsh命令。先輸入賬戶密碼,然後輸入新Shell型別,如果操作正確系統會顯示“Shell change”。其界面一般如下:

Changing fihanging shell for cao
Password:
New shell [/bin/bash]: /bin/tcsh

上面代碼中,[ ]內是目前使用的Shell。普通用戶只能修改自己的Shell,超級用戶可以修改全體用戶的Shell。要想查詢系統提供哪些Shell,可以使用chsh -l 命令,見圖1所示。

圖1 系統可以使用的Shell型別

從圖1中可以看到,筆者系統中可以使用的Shell有bash(預設)、csh、sh、tcsh四種。

exit

1.作用

exit命令的作用是退出系統,它的使用權限是所有用戶。

2.格式

exit

3.引數

exit命令沒有引數,運行後退出系統進入登錄界面。

last

1.作用

last命令的作用是顯示近期用戶或終端的登錄情況,它的使用權限是所有用戶。通過last命令查看該程式的log,管理員可以獲知誰曾經或企圖連接系統。

2.格式

1ast[—n][-f file][-t tty] [—h 節點][-I —IP][—1][-y][1D]

3.主要引數

-n:指定輸出記錄的條數。

-f file:指定用檔案file作為查詢用的log檔案。

-t tty:只顯示指定的虛擬控制臺上登錄情況。

-h 節點:只顯示指定的節點上的登錄情況。

-i IP:只顯示指定的IP上登錄的情況。

-1:用IP來顯示遠端地址。

-y:顯示記錄的年、月、日。

-ID:知道查詢的用戶名。

-x:顯示系統關閉、用戶登錄和退出的歷史。

動手練習

上面介紹了Linux安裝和登錄命令,下麵介紹幾個實體,動手練習一下剛纔講過的命令。

1.一次運行多個命令

在一個命令列中可以執行多個命令,用分號將各個命令隔開即可,例如:

#last -x;halt

上面代碼表示在顯示系統關閉、用戶登錄和退出的歷史後關閉計算機。

2.利用mount掛裝檔案系統訪問Windows系統

許多Linux發行版本現在都可以自動加載Vfat分割槽來訪問Windows系統,而Red Hat各個版本都沒有自動加載Vfat分割槽,因此還需要進行手工操作。

mount可以將Windows分割槽作為Linux的一個“檔案”掛接到Linux的一個空檔案夾下,從而將Windows的分割槽和/mnt這個目錄聯繫起來。因此,只要訪問這個檔案夾就相當於訪問該分割槽了。首先要在/mnt下建立winc檔案夾,在命令提示符下輸入下麵命令:

#mount -t vfat /dev/hda1 /mnt/winc

即表示將Windows的C分割槽掛到Liunx的/mnt/winc目錄下。這時,在/mnt/winc目錄下就可以看到Windows中C盤的內容了。使用類似的方法可以訪問Windows系統的D、E盤。在Linux系統顯示Windows的分割槽一般順序這樣的:hda1為C盤、hda5為D盤、 hda6為E盤……以此類推。上述方法可以查看Windows系統有一個很大的問題,就是Windows中的所有中文檔案名或檔案夾名全部顯示為問號 “?”,而英文卻可以正常顯示。我們可以通過加入一些引數讓它顯示中文。還以上面的操作為例,此時輸入命令:

#mount -t vfat -o iocharset=cp936 /dev/hda1 /mnt/winc

現在它就可以正常顯示中文了。

3.使用mount加掛閃盤上的檔案系統

在Linux下使用閃盤非常簡單。Linux對USB設備有很好的支持,當插入閃盤後,閃盤被識別為一個SCSI盤,通常輸入以下命令:

# mount /dev/sda1 /usb

就能夠加掛閃盤上的檔案系統。

小知識

Linux命令與Shell

所謂Shell,就是命令解釋程式,它提供了程式設計接口,可以使用程式來編程。學習Shell對於Linux初學者理解Linux系統是非常重要的。 Linux系統的Shell作為操作系統的外殼,為用戶提供了使用操作系統的接口。Shell是命令語言、命令解釋程式及程式設計語言的統稱,是用戶和 Linux內核之間的接口程式。如果把Linux內核想象成一個球體的中心,Shell就是圍繞內核的外層。當從Shell或其它程式向Linux傳遞命令時,內核會做出相應的反應。Shell在Linux系統的作用和MS DOS下的COMMAND.COM和Windows 95/98 的 explorer.exe相似。Shell雖然不是系統核心的一部分,只是系統核心的一個外延,但它能夠呼叫系統內核的大部分功能。因此,可以說 Shell是Unux/Linux最重要的實用程式。

Linux中的Shell有多種型別,其中最常用的是Bourne Shell(sh)、C Shell(csh)和Korn Shell(ksh)。大多數Linux發行版本預設的Shell是Bourne Again Shell,它是Bourne Shell的擴展,簡稱bash,與Bourne Shell完全向後兼容,並且在Bourne Shell的基礎上增加了很多特性。bash放在/bin/bash中,可以提供如命令補全、命令編輯和命令歷史表等功能。它還包含了很多C Shell和Korn Shell中的優點,有靈活和強大的編程接口,同時又有很友好的用戶界面。Linux系統中200多個命令中有40個是bash的內部命令,主要包括 exit、less、lp、kill、 cd、pwd、fc、fg等。


 Linux必學的60個命令(2)-檔案處理命令

Linux 系統信息存放在檔案里,檔案與普通的公務檔案類似。每個檔案都有自己的名字、內容、存放地址及其它一些管理信息,如檔案的用戶、檔案的大小等。檔案可以是一封信、一個通訊錄,或者是程式的源陳述句、程式的資料,甚至可以包括可執行的程式和其它非正文內容。 Linux檔案系統具有良好的結構,系統提供了很多檔案處理程式。這裡主要介紹常用的檔案處理命令。

file

1.作用 件內容判斷檔案型別,使用權限是所有用戶。

2.格式

file通過探測文

file [options] 檔案名

3.[options]主要引數

-v:在標準輸出後顯示版本信息,並且退出。

-z:探測壓縮過的檔案型別。

-L:允許符合連接。

-f name:從檔案namefile中讀取要分析的檔案名串列。

4.簡單說明

使用file命令可以知道某個檔案究竟是二進制(ELF格式)的可執行檔案, 還是Shell Script檔案,或者是其它的什麼格式。file能識別的檔案型別有目錄、Shell腳本、英文文本、二進制可執行檔案、C語言源檔案、文本檔案、DOS的可執行檔案。

5.應用實體

如果我們看到一個沒有後綴的檔案grap,可以使用下麵命令:

$ file grap

grap: English text

此時系統顯示這是一個英文文本檔案。需要說明的是,file命令不能探測包括圖形、音頻、視頻等多媒體檔案型別。

mkdir

1.作用

mkdir命令的作用是建立名稱為dirname的子目錄,與MS DOS下的md命令類似,它的使用權限是所有用戶。

2.格式

mkdir [options] 目錄名

3.[options]主要引數

-m, --mode=樣式:設定權限,與chmod類似。

-p, --parents:需要時創建上層目錄;如果目錄早已存在,則不當作錯誤。

-v, --verbose:每次創建新目錄都顯示信息。

--version:顯示版本信息後離開。

4.應用實體

在進行目錄創建時可以設置目錄的權限,此時使用的引數是“-m”。假設要創建的目錄名是“tsk”,讓所有用戶都有rwx(即讀、寫、執行的權限),那麼可以使用以下命令:

$ mkdir -m 777 tsk

grep

1.作用

grep命令可以指定檔案中搜索特定的內容,並將含有這些內容的行標準輸出。grep全稱是Global Regular Expression Print,表示全域性正則運算式版本,它的使用權限是所有用戶。

2.格式

grep [options]

3.主要引數

[options]主要引數:

-c:只輸出匹配行的計數。

-I:不區分大小寫(只適用於單字符)。

-h:查詢多檔案時不顯示檔案名。

-l:查詢多檔案時只輸出包含匹配字符的檔案名。

-n:顯示匹配行及行號。

-s:不顯示不存在或無匹配文本的錯誤信息。

-v:顯示不包含匹配文本的所有行。

pattern正則運算式主要引數:

/:忽略正則運算式中特殊字符的原有含義。

^:匹配正則運算式的開始行。

$: 匹配正則運算式的結束行。

/

/>:到匹配正則運算式的行結束。

[ ]:單個字符,如[A]即A符合要求 。

[ – ]:範圍,如[A-Z],即A、B、C一直到Z都符合要求 。

。:所有的單個字符。

* :有字符,長度可以為0。

正則運算式是Linux/Unix系統中非常重要的概念。正則運算式(也稱為“regex”或“regexp”)是一個可以描述一類字串的樣式(Pattern)。如果一個字串可以用某個正則運算式來描述,我們就說這個字符和該正則運算式匹配(Match)。這和DOS中用戶可以使用通配符 “*”代表任意字符類似。在Linux系統上,正則運算式通常被用來查找文本的樣式,以及對文本執行“搜索-替換”操作和其它功能。

4.應用實體

查詢DNS服務是日常工作之一,這意味著要維護改寫不同網絡的大量IP地址。有時IP地址會超過2000個。如果要查看nnn.nnn網絡地址,但是卻忘了第二部分中的其餘部分,只知到有兩個句點,例如nnn nn..。要抽取其中所有nnn.nnn IP地址,使用[0-9 ]/{3 /}/.[0-0/{3/}/。含義是任意數字出現3次,後跟句點,接著是任意數字出現3次,後跟句點。

$grep ‘[0-9 ]/{3 /}/.[0-0/{3/}/’ ipfile

補充說明,grep家族還包括fgrep和egrep。fgrep是fix grep,允許查找字串而不是一個樣式;egrep是擴展grep,支持基本及擴展的正則運算式,但不支持/q樣式範圍的應用及與之相對應的一些更加規範的樣式。

dd

1.作用

dd命令用來複制檔案,並根據引數將資料轉換和格式化。

2.格式

dd [options]

3.[opitions]主要引數

bs=位元組:強迫 ibs=及obs=。

cbs=位元組:每次轉換指定的。

conv=關鍵字:根據以逗號分隔的關鍵字表示的方式來轉換檔案。

count=塊數目:只複製指定的輸入資料。

ibs=位元組:每次讀取指定的。

if=檔案:讀取內容,而非標準輸入的資料。

obs=位元組:每次寫入指定的。

of=檔案:將資料寫入,而不在標準輸出顯示。

seek=塊數目:先略過以obs為單位的指定的輸出資料。

skip=塊數目:先略過以ibs為單位的指定的輸入資料。

4.應用實體

dd命令常常用來製作Linux啟動盤。先找一個可引導內核,令它的根設備指向正確的根分割槽,然後使用dd命令將其寫入軟盤:

$ rdev vmlinuz /dev/hda

$dd if=vmlinuz of=/dev/fd0

上面代碼說明,使用rdev命令將可引導內核vmlinuz中的根設備指向/dev/hda,請把“hda”換成自己的根分割槽,接下來用dd命令將該內核寫入軟盤。


find

1.作用

find命令的作用是在目錄中搜索檔案,它的使用權限是所有用戶。

2.格式

find [path][options][expression]

path指定目錄路徑,系統從這裡開始沿著目錄樹向下查找檔案。它是一個路徑串列,相互用空格分離,如果不寫path,那麼預設為當前目錄。

3.主要引數

[options]引數:

-depth:使用深度級別的查找過程方式,在某層指定目錄中優先查找檔案內容。

-maxdepth levels:表示至多查找到開始目錄的第level層子目錄。level是一個非負數,如果level是0的話表示僅在當前目錄中查找。

-mindepth levels:表示至少查找到開始目錄的第level層子目錄。

-mount:不在其它檔案系統(如Msdos、Vfat等)的目錄和檔案中查找。

-version:打印版本。

[expression]是匹配運算式,是find命令接受的運算式,find命令的所有操作都是針對運算式的。它的引數非常多,這裡只介紹一些常用的引數。

—name:支持統配符*和?。

-atime n:搜索在過去n天讀取過的檔案。

-ctime n:搜索在過去n天修改過的檔案。

-group grpoupname:搜索所有組為grpoupname的檔案。

-user 用戶名:搜索所有檔案屬主為用戶名(ID或名稱)的檔案。

-size n:搜索檔案大小是n個block的檔案。

-print:輸出搜索結果,並且打印。

4.應用技巧

find命令查找檔案的幾種方法:

(1)根據檔案名查找

例如,我們想要查找一個檔案名是lilo.conf的檔案,可以使用如下命令:

find / -name lilo.conf

find命令後的“/”表示搜索整個硬碟。

(2)快速查找檔案

根據檔案名查找檔案會遇到一個實際問題,就是要花費相當長的一段時間,特別是大型Linux檔案系統和大容量硬碟檔案放在很深的子目錄中時。如果我們知道了這個檔案存放在某個目錄中,那麼只要在這個目錄中往下尋找就能節省很多時間。比如smb.conf檔案,從它的檔案後綴“.conf”可以判斷這是一個配置檔案,那麼它應該在/etc目錄內,此時可以使用下麵命令:

find /etc -name smb.conf

這樣,使用“快速查找檔案”方式可以縮短時間。

(3)根據部分檔案名查找方法

有時我們知道只某個檔案包含有abvd這4個字,那麼要查找系統中所有包含有這4個字符的檔案可以輸入下麵命令:

find / -name ‘*abvd*’

輸入這個命令以後,Linux系統會將在/目錄中查找所有的包含有abvd這4個字符的檔案(其中*是通配符),比如abvdrmyz等符合條件的檔案都能顯示出來。

(4) 使用混合查找方式查找檔案

find命令可以使用混合查找的方法,例如,我們想在/etc目錄中查找大於500000位元組,並且在24小時內修改的某個檔案,則可以使用-and (與)把兩個查找引數鏈接起來組合成一個混合的查找方式。

find /etc -size +500000c -and -mtime +1

mv

1.作用

mv命令用來為檔案或目錄改名,或者將檔案由一個目錄移入另一個目錄中,它的使用權限是所有用戶。該命令如同DOS命令中的ren和move的組合。

2.格式

mv[options] 源檔案或目錄 標的檔案或目錄

3.[options]主要引數

-i:交互方式操作。如果mv操作將導致對已存在的標的檔案的改寫,此時系統詢問是否重寫,要求用戶回答“y”或“n”,這樣可以避免誤改寫檔案。

-f:禁止交互操作。mv操作要改寫某個已有的標的檔案時不給任何指示,指定此引數後i引數將不再起作用。

4.應用實體

(1)將/usr/cbu中的所有檔案移到當前目錄(用“.”表示)中:

$ mv /usr/cbu/ * .

(2)將檔案cjh.txt重命名為wjz.txt:

$ mv cjh.txt wjz.txt 

ls

1.作用

ls命令用於顯示目錄內容,類似DOS下的dir命令,它的使用權限是所有用戶。

2.格式

ls [options][filename]

3.options主要引數

-a, --all:不隱藏任何以“.” 字符開始的專案。

-A, --almost-all:列出除了“ . ”及 “.. ”以外的任何專案。

--author:印出每個檔案著作者。

-b, --escape:以八進制上限溢位序串列示不可打印的字符。

--block-size=大小:塊以指定的位元組為單位。

-B, --ignore-backups:不列出任何以 ~ 字符結束的專案。

-f:不進行排序,-aU引數生效,-lst引數失效。

-F, --classify:加上檔案型別的指示符號 (*/[email protected]| 其中一個)。

-g:like -l, but do not list owner。

-G, --no-group:inhibit display of group information。

-i, --inode:列出每個檔案的inode號。

-I, --ignore=樣式:不印出任何符合Shell萬用字符的專案。

-k:即--block-size=1K。

-l:使用較長格式列出信息。

-L, --dereference:當顯示符號鏈接的檔案信息時,顯示符號鏈接所指示的物件,而並非符號鏈接本身的信息。

-m:所有專案以逗號分隔,並填滿整行行寬。

-n, --numeric-uid-gid:類似-l,但列出UID及GID號。

-N, --literal:列出未經處理的專案名稱,例如不特別處理控制字符。

-p, --file-type:加上檔案型別的指示符號 (/[email protected]| 其中一個)。

-Q, --quote-name:將專案名稱括上雙引號。

-r, --reverse:依相反次序排列。

-R, --recursive:同時列出所有子目錄層。

-s, --size:以塊大小為序。

4.應用舉例

ls 命令是Linux系統使用頻率最多的命令,它的引數也是Linux命令中最多的。使用ls命令時會有幾種不同的顏色,其中藍色表示是目錄,綠色表示是可執行檔案,紅色表示是壓縮檔案,淺藍色表示是鏈接檔案,加粗的黑色表示符號鏈接,灰色表示是其它格式檔案。ls最常使用的是ls- l,見圖1所示。

圖1 使用ls-l命令

檔案型別開頭是由10個字符構成的字串。其中第一個字符表示檔案型別,它可以是下述型別之一:-(普通檔案)、d(目錄)、l(符號鏈接)、b(塊設備檔案)、c(字符設備檔案)。後面的9個字符表示檔案的訪問權限,分為3組,每組3位。第一組表示檔案屬主的權限,第二組表示同組用戶的權限,第三組表示其他用戶的權限。每一組的三個字符分別表示對檔案的讀(r)、寫(w)和執行權限(x)。對於目錄,表示進入權限。s表示當檔案被執行時,把該檔案的UID 或GID賦予執行行程的UID(用戶ID)或GID(組 ID)。t表示設置標誌位(留在記憶體,不被換出)。如果該檔案是目錄,那麼在該目錄中的檔案只能被超級用戶、目錄擁有者或檔案屬主刪除。如果它是可執行檔案,那麼在該檔案執行後,指向其正文段的指標仍留在記憶體。這樣再次執行它時,系統就能更快地裝入該檔案。接著顯示的是檔案大小、生成時間、檔案或命令名稱。


diff

1.作用

diff命令用於兩個檔案之間的比較,並指出兩者的不同,它的使用權限是所有用戶。

2.格式

diff [options] 源檔案 標的檔案

3.[options]主要引數

-a:將所有檔案當作文本檔案來處理。

-b:忽略空格造成的不同。

-B:忽略空行造成的不同。

-c:使用綱要輸出格式。

-H:利用試探法加速對大檔案的搜索。

-I:忽略大小寫的變化。

-n –rcs:輸出RCS格式。

cmp

1.作用

cmp(“compare”的縮寫)命令用來簡要指出兩個檔案是否存在差異,它的使用權限是所有用戶。

2.格式

cmp[options] 檔案名

3.[options]主要引數

-l: 將位元組以十進制的方式輸出,並方便將兩個檔案中不同的以八進制的方式輸出。

cat

1.作用

cat(“concatenate”的縮寫)命令用於連接並顯示指定的一個和多個檔案的有關信息,它的使用權限是所有用戶。

2.格式

cat [options] 檔案1 檔案2……

3.[options]主要引數

-n:由第一行開始對所有輸出的行數編號。

-b:和-n相似,只不過對於空白行不編號。

-s:當遇到有連續兩行以上的空白行時,就代換為一行的空白行。

4.應用舉例

(1)cat命令一個最簡單的用處是顯示文本檔案的內容。例如,我們想在命令列看一下README檔案的內容,可以使用命令:

$ cat README 

(2)有時需要將幾個檔案處理成一個檔案,並將這種處理的結果儲存到一個單獨的輸出檔案。cat命令在其輸入上接受一個或多個檔案,並將它們作為一個單獨的檔案打印到它的輸出。例如,把README和INSTALL的檔案內容加上行號(空白行不加)之後,將內容附加到一個新文本檔案File1 中:

$ cat README INSTALL File1

(3)cat還有一個重要的功能就是可以對行進行編號,見圖2所示。這種功能對於程式文件的編製,以及法律和科學文件的編製很方便,打印在左邊的行號使得參考文件的某一部分變得容易,這些在編程、科學研究、業務報告甚至是立法工作中都是非常重要的。

圖2 使用cat命令/etc/named.conf檔案進行編號

對行進行編號功能有-b(只能對非空白行進行編號)和-n(可以對所有行進行編號)兩個引數:

$ cat -b /etc/named.conf

ln

1.作用

ln命令用來在檔案之間創建鏈接,它的使用權限是所有用戶。

2.格式

ln [options] 源檔案 [鏈接名]

3.引數

-f:鏈結時先將源檔案刪除。

-d:允許系統管理者硬鏈結自己的目錄。

-s:進行軟鏈結(Symbolic Link)。

-b:將在鏈結時會被改寫或刪除的檔案進行備份。

鏈接有兩種,一種被稱為硬鏈接(Hard Link),另一種被稱為符號鏈接(Symbolic Link)。預設情況下,ln命令產生硬鏈接。

硬連接指通過索引節點來進行的連接。在Linux的檔案系統中,儲存在磁盤分割槽中的檔案不管是什麼型別都給它分配一個編號,稱為索引節點號(Inode Index)。在Linux中,多個檔案名指向同一索引節點是存在的。一般這種連接就是硬連接。硬連接的作用是允許一個檔案擁有多個有效路徑名,這樣用戶就可以建立硬連接到重要檔案,以防止“誤刪”的功能。其原因如上所述,因為對應該目錄的索引節點有一個以上的連接。只刪除一個連接並不影響索引節點本身和其它的連接,只有當最後一個連接被刪除後,檔案的資料塊及目錄的連接才會被釋放。也就是說,檔案才會被真正刪除。

與硬連接相對應,Lnux系統中還存在另一種連接,稱為符號連接(Symbilc Link),也叫軟連接。軟鏈接檔案有點類似於Windows的快捷方式。它實際上是特殊檔案的一種。在符號連接中,檔案實際上是一個文本檔案,其中包含的有另一檔案的位置信息。

動手練習

上面我們介紹了Linux檔案處理命令,下麵介紹幾個實體,大家可以動手練習一下剛纔講過的命令。

1.利用符號鏈接快速訪問關鍵目錄

符號鏈接是一個非常實用的功能。假設有一些目錄或檔案需要頻繁使用,但由於Linux的檔案和目錄結構等原因,這個檔案或目錄在很深的子目錄中。比如, Apache Web服務器文件位於系統的/usr/local/httpd/htdocs中,並且不想每次都要從主目錄進入這樣一個長的路徑之中(實際上,這個路徑也非常不容易記憶)。

為瞭解決這個問題,可以在主目錄中創建一個符號鏈接,這樣在需要進入該目錄時,只需進入這個鏈接即可。

為了能方便地進入Web服務器(/usr/local/httpd/htdocs)文件所在的目錄,在主目錄下可以使用以下命令:

$ ln -s /usr/local/httpd/htdocs gg

這樣每次進入gg目錄就可訪問Web服務器的文件,以後如果不再訪問Web服務器的文件時,刪除gg即可,而真正的Web服務器的文件並沒有刪除。

2.使用dd命令將init.rd格式的root.ram內容匯入記憶體

dd if=/dev/fd0 of=floppy.fd

dd if=root.ram of=/dev/ram0 #

3.grep命令系統呼叫

grep是Linux/Unix中使用最廣泛的命令之一,許多Linux系統內部都可以呼叫它。

(1)如果要查詢目錄串列中的目錄,方法如下:

$ ls -l | grep ‘∧d’

(2)如果在一個目錄中查詢不包含目錄的所有檔案,方法如下:

$ ls -l | grep ‘∧[∧d]’

(3)用find命令呼叫grep,如所有C原始碼中的“Chinput”,方法如下:

$find /ZhXwin -name *.c -exec grep -q -s Chinput {} /;-print


Linux必學的60個命令(3)-系統管理命令

對於Linux系統來說,無論是中央處理器、記憶體、磁盤驅動器、鍵盤、滑鼠,還是用戶等都是檔案,Linux系統管理的命令是它正常運行的核心。熟悉了Linux常用的檔案處理命令以後,這一講介紹對系統和用戶進行管理的命令。

df

1.作用
df命令用來檢查檔案系統的磁盤空間占用情況,使用權限是所有用戶。

2.格式
df [options]

3.主要引數
-s:對每個Names引數只給出占用的資料塊總數。
-a:遞迴地顯示指定目錄中各檔案及子目錄中各檔案占用的資料塊數。若既不指定-s,也不指定-a,則只顯示Names中的每一個目錄及其中的各子目錄所占的磁盤塊數。
-k:以1024位元組為單位列出磁盤空間使用情況。
-x:跳過在不同檔案系統上的目錄不予統計。
-l:計算所有的檔案大小,對硬鏈接檔案則計算多次。
-i:顯示inode信息而非塊使用量。
-h:以容易理解的格式印出檔案系統大小,例如136KB、254MB、21GB。
-P:使用POSIX輸出格式。
-T:顯示檔案系統型別。

4.說明
df命令被廣泛地用來生成檔案系統的使用統計資料,它能顯示系統中所有的檔案系統的信息,包括總容量、可用的空閑空間、目前的安裝點等。

超級權限用戶使用df命令時會發現這樣的情況:某個分割槽的容量超過了100%。這是因為Linux系統為超級用戶保留了10%的空間,由其單獨支配。也就是說,對於超級用戶而言,他所見到的硬碟容量將是110%。這樣的安排對於系統管理而言是有好處的,當硬碟被使用的容量接近100%時系統管理員還可以正常工作。

5.應用實體
Linux支持的檔案系統非常多,包括JFS、ReiserFS、ext、ext2、ext3、ISO9660、XFS、Minx、vfat、MSDOS等。使用df -T命令查看磁盤空間時還可以得到檔案系統的信息:

#df -T
檔案系統 型別 容量 已用 可用 已用% 掛載點
/dev/hda7 reiserfs 5.2G 1.6G 3.7G 30% /
/dev/hda1 vfat 2.4G 1.6G 827M 66% /windows/C
/dev/hda5 vfat 3.0G 1.7G 1.3G 57% /windows/D
/dev/hda9 vfat 3.0G 2.4G 566M 82% /windows/E
/dev/hda10 NTFS 3.2G 573M 2.6G 18% /windows/F
/dev/hda11 vfat 1.6G 1.5G 23M 99% /windows/G

從上面除了可以看到磁盤空間的容量、使用情況外,分割槽的檔案系統型別、掛載點等信息也一覽無遺。

top

1.作用
top命令用來顯示執行中的程式行程,使用權限是所有用戶。

2.格式
top [-] [d delay] [q] [c] [S] [s] [i] [n]

3.主要引數
d:指定更新的間隔,以秒計算。
q:沒有任何延遲的更新。如果使用者有超級用戶,則top命令將會以最高的優先序執行。
c:顯示行程完整的路徑與名稱。
S:累積樣式,會將己完成或消失的子行程的CPU時間累積起來。
s:安全樣式。
i:不顯示任何閑置(Idle)或無用(Zombie)的行程。
n:顯示更新的次數,完成後將會退出top。

4.說明
top命令是Linux系統管理的一個主要命令,通過它可以獲得許多信息。這裡我們結合圖1來說明它給出的信息。

圖1 top命令的顯示

在圖1中,第一行表示的專案依次為當前時間、系統啟動時間、當前系統登錄用戶數目、平均負載。第二行顯示的是所有啟動的行程、目前運行的、掛起 (Sleeping)的和無用(Zombie)的行程。第三行顯示的是目前CPU的使用情況,包括系統占用的比例、用戶使用比例、閑置(Idle)比例。第四行顯示物理記憶體的使用情況,包括總的可以使用的記憶體、已用記憶體、空閑記憶體、緩衝區占用的記憶體。第五行顯示交換分割槽使用情況,包括總的交換分割槽、使用的、空閑的和用於高速快取的大小。第六行顯示的專案最多,下麵列出了詳細解釋。
PID(Process ID):行程標示號。
USER:行程所有者的用戶名。
PR:行程的優先級別。
NI:行程的優先級別數值。
VIRT:行程占用的虛擬記憶體值。
RES:行程占用的物理記憶體值。
SHR:行程使用的共享記憶體值。
S:行程的狀態,其中S表示休眠,R表示正在運行,Z表示僵死狀態,N表示該行程優先值是負數。
%CPU:該行程占用的CPU使用率。
%MEM:該行程占用的物理記憶體和總記憶體的百分比。
TIME+:該行程啟動後占用的總的CPU時間。
Command:行程啟動的啟動命令名稱,如果這一行顯示不下,行程會有一個完整的命令列。
top命令使用過程中,還可以使用一些交互的命令來完成其它引數的功能。這些命令是通過快捷鍵啟動的。
:立刻掃清。
P:根據CPU使用大小進行排序。
T:根據時間、累計時間排序。
q:退出top命令。
m:切換顯示記憶體信息。
t:切換顯示行程和CPU狀態信息。
c:切換顯示命令名稱和完整命令列。
M:根據使用記憶體大小進行排序。
W:將當前設置寫入~/.toprc檔案中。這是寫top配置檔案的推薦方法。

可以看到,top命令是一個功能十分強大的監控系統的工具,對於系統管理員而言尤其重要。但是,它的缺點是會消耗很多系統資源。

5.應用實體
使用top命令可以監視指定用戶,預設情況是監視所有用戶的行程。如果想查看指定用戶的情況,在終端中按“U”鍵,然後輸入用戶名,系統就會切換為指定用戶的行程運行界面,見圖2所示。

圖2 使用top命令監視指定用戶

free

1.作用
free命令用來顯示記憶體的使用情況,使用權限是所有用戶。

2.格式
free [-b|-k|-m] [-o] [-s delay] [-t] [-V]

3.主要引數
-b -k -m:分別以位元組(KB、MB)為單位顯示記憶體使用情況。
-s delay:顯示每隔多少秒數來顯示一次記憶體使用情況。
-t:顯示記憶體總和列。
-o:不顯示緩衝區調節列。

4.應用實體
free命令是用來查看記憶體使用情況的主要命令。和top命令相比,它的優點是使用簡單,並且只占用很少的系統資源。通過-S引數可以使用free命令不間斷地監視有多少記憶體在使用,這樣可以把它當作一個方便實時監控器。
#free -b -s5

使用這個命令後終端會連續不斷地報告記憶體使用情況(以位元組為單位),每5秒更新一次。

quota

1.作用
quota命令用來顯示磁盤使用情況和限制情況,使用權限超級用戶。

2.格式
quota [-g][-u][-v][-p] 用戶名 組名

3.引數
-g:顯示用戶所在組的磁盤使用限制。
-u:顯示用戶的磁盤使用限制。
-v:顯示沒有分配空間的檔案系統的分配情況。
-p:顯示簡化信息。

4.應用實體
在企業應用中磁盤配額非常重要,普通用戶要學會看懂自己的磁盤使用情況。要查詢自己的磁盤配額可以使用下麵命令(下例中用戶賬號是caojh):

#quota caojh
Disk quotas for user caojh(uid 502):
Filesystem blocks quota limit grace files quota limit grace
/dev/hda3 58 200000 400000 41 500 1000

以上顯示ID號為502的caojh賬號,檔案個數設置為500~1000個,硬碟空間限制設置為200MB~400MB。一旦磁盤配額要用完時,就需要刪除一些垃圾檔案或向系統管理員請求追加配額。

at

1.作用
at命令用來在指定時刻執行指定的命令序列。

2.格式
at [-V] [-q x] [-f file] [-m] time

3.主要引數
-V:顯示標準錯誤輸出。
-q:許多佇列輸出。
-f:從檔案中讀取作業。
-m:執行完作業後發送電子郵件到用戶。
time:設定作業執行的時間。time格式有嚴格的要求,由小時、分鐘、日期和時間的偏移量組成,其中日期的格式為MM.DD.YY,MM是分鐘,DD是日期,YY是指年份。偏移量的格式為時間+偏移量,單位是minutes、hours和days。

4.應用實體
#at -f data 15:30 +2 days

上面命令表示讓系統在兩天后的17:30執行檔案data中指明的作業。

lp

1.作用
lp是打印檔案的命令,使用權限是所有用戶。

2.格式
lp [-c][-d][-m][-number][-title][-p]

3.主要引數
-c:先拷貝檔案再打印。
-d:打印佇列檔案。
-m:打印結束後發送電子郵件到用戶。
-number:打印份數。
-title:打印標題。
-p:設定打印的優先級別,最高為100。

4.應用實體
(1)使用lp命令打印多個檔案
#lp 2 3 4
request id is 11 (3 file(s))

其中2、3、4分別是檔案名;“request id is 11 (3 file(s)) ”表示這是第11個打印命令,依次打印這三個檔案。

(2)設定打印優先級別
#lp lp -d LaserJet -p 90 /etc/aliases

通過添加“-p 90”,規定了打印作業的優先級為90。它將在優先級低於90的打印作業之前打印,包括沒有設置優先級的作業,預設優先級是50

useradd

1.作用
useradd命令用來建立用戶帳號和創建用戶的起始目錄,使用權限是超級用戶。

2.格式
useradd [-d home] [-s shell] [-c comment] [-m [-k template]] [-f inactive] [-e expire ] [-p passwd] [-r] name

3.主要引數
-c:加上備註文字,備註文字儲存在passwd的備註欄中。 
-d:指定用戶登入時的啟始目錄。
-D:變更預設值。
-e:指定賬號的有效期限,預設表示永久有效。
-f:指定在密碼過期後多少天即關閉該賬號。
-g:指定用戶所屬的群組。
-G:指定用戶所屬的附加群組。
-m:自動建立用戶的登入目錄。
-M:不要自動建立用戶的登入目錄。
-n:取消建立以用戶名稱為名的群組。
-r:建立系統賬號。
-s:指定用戶登入後所使用的shell。
-u:指定用戶ID號。

4.說明
useradd可用來建立用戶賬號,它和adduser命令是相同的。賬號建好之後,再用passwd設定賬號的密碼。使用useradd命令所建立的賬號,實際上是儲存在/etc/passwd文本檔案中。

5.應用實體
建立一個新用戶賬戶,並設置ID:
#useradd caojh -u 544

需要說明的是,設定ID值時儘量要大於500,以免衝突。因為Linux安裝後會建立一些特殊用戶,一般0到499之間的值留給bin、mail這樣的系統賬號。

groupadd

1.作用
groupadd命令用於將新組加入系統。

2.格式
groupadd [-g gid] [-o]] [-r] [-f] groupname

3.主要引數
-g gid:指定組ID號。
-o:允許組ID號,不必惟一。
-r:加入組ID號,低於499系統賬號。
-f:加入已經有的組時,發展程式退出。

4.應用實體
建立一個新組,並設置組ID加入系統:
#groupadd -g 344 cjh

此時在/etc/passwd檔案中產生一個組ID(GID)是344的專案。

kill

1.作用
kill命令用來中止一個行程。

2.格式
kill [ -s signal | -p ] [ -a ] pid …
kill -l [ signal ]

3.引數
-s:指定發送的信號。
-p:模擬發送信號。
-l:指定信號的名稱串列。
pid:要中止行程的ID號。
Signal:表示信號。

4.說明
行程是Linux系統中一個非常重要的概念。Linux是一個多任務的操作系統,系統上經常同時運行著多個行程。我們不關心這些行程究竟是如何分配的,或者是內核如何管理分配時間片的,所關心的是如何去控制這些行程,讓它們能夠很好地為用戶服務。

Linux 操作系統包括三種不同型別的行程,每種行程都有自己的特點和屬性。交互行程是由一個Shell啟動的行程。交互行程既可以在前臺運行,也可以在後臺運行。批處理行程和終端沒有聯繫,是一個行程序列。監控行程(也稱系統守護行程)時Linux系統啟動時啟動的行程,併在後臺運行。例如,httpd是著名的 Apache服務器的監控行程。

kill命令的工作原理是,向Linux系統的內核發送一個系統操作信號和某個程式的行程標識號,然後系統內核就可以對行程標識號指定的行程進行操作。比如在top命令中,我們看到系統運行許多行程,有時就需要使用kill中止某些行程來提高系統資源。在講解安裝和登陸命令時,曾提到系統多個虛擬控制台的作用是當一個程式出錯造成系統死鎖時,可以切換到其它虛擬控制台工作關閉這個程式。此時使用的命令就是kill,因為kill是大多數Shell內部命令可以直接呼叫的。

5.應用實體
(1)強行中止(經常使用殺掉)一個行程標識號為324的行程:
#kill -9 324

(2)解除Linux系統的死鎖
在Linux 中有時會發生這樣一種情況:一個程式崩潰,並且處於死鎖的狀態。此時一般不用重新啟動計算機,只需要中止(或者說是關閉)這個有問題的程式即可。當 kill處於X-Window界面時,主要的程式(除了崩潰的程式之外)一般都已經正常啟動了。此時打開一個終端,在那裡中止有問題的程式。比如,如果 Mozilla瀏覽器程式出現了鎖死的情況,可以使用kill命令來中止所有包含有Mozolla瀏覽器的程式。首先用top命令查處該程式的PID,然後使用kill命令停止這個程式:
#kill -SIGKILL XXX
其中,XXX是包含有Mozolla瀏覽器的程式的行程標識號。

(3)使用命令回收記憶體
我們知道記憶體對於系統是非常重要的,回收記憶體可以提高系統資源。kill命令可以及時地中止一些“越軌”的程式或很長時間沒有相應的程式。例如,使用top命令發現一個無用 (Zombie) 的行程,此時可以使用下麵命令:
#kill -9 XXX
其中,XXX是無用的行程標識號。

然後使用下麵命令:
#free
此時會發現可用記憶體容量增加了。

(4)killall命令
Linux下還提供了一個killall命令,可以直接使用行程的名字而不是行程標識號,例如:
# killall -HUP inetd

crontab

1.作用
使用crontab命令可以修改crontab配置檔案,然後該配置由cron公用程式在適當的時間執行,該命令使用權限是所有用戶。

2.格式
crontab [ -u user ] 檔案
crontab [ -u user ] { -l | -r | -e }

3.主要引數
-e:執行文字編輯器來設定時程表,內定的文字編輯器是vi。
-r:刪除目前的時程表。
-l:列出目前的時程表。

crontab 檔案的格式為“M H D m d cmd”。其中,M代表分鐘(0~59),H代表小時(0~23),D代表天(1~31),m代表月(1~12),d代表一星期內的天(0~6,0為星期天)。cmd表示要運行的程式,它被送入sh執行,這個Shell只有USER、HOME、SHELL三個環境變數。

4.說明
和at命令相比,crontab命令適合完成固定周期的任務。

5.應用實體
設置一個定時、定期的系統提示:
[cao @www cao]#crontab -e
此時系統會打開一個vi編輯器。

如果輸入以下內容:35 17 * * 5 wall “Tomorrow is Saturday I will go CS”,然後存盤退出。這時在/var/spool/cron/目錄下會生產一個cao的檔案,內容如下:

# DO NOT EDIT THIS FILE - edit the master and reinstall.
# (/tmp/crontab.2707 installed on Thu Jan 1 22:01:51 2004)
# (Cron version -- $Id: crontab.c,v 2.13 1994/01/17 03:20:37 vixie Exp $)
35 17 * * 5 wall “Tomorrow is Saturday I will play CS “

這樣每個星期五17:35系統就會彈出一個終端,提醒星期六可以打打CS了!顯示結果見圖3所示。

圖3 一個定時、定期的系統提示

動手練習

1.聯合使用kill和top命令觀察系統性能的變化

首先啟動一個終端運行top命令,然後再啟動一個終端使用kill命令,見圖4所示。

圖4 觀察kill命令對top終端的影響

這時利用上面介紹的kill命令來中止一些程式:
#kill SIGKILL XXX

然後再看top命令終端的變化,包括記憶體容量、CPU使用率、系統負載等。註意,有些行程是不能中止的,不過學習Linux命令時可以試試,看看系統有什麼反應。

2.使用at和halt命令定時關機
首先設定關機時間是17:35,輸入下麵代碼:

#at 17:35
warning: commands will be executed using (in order) a) $SHELL b) login shell c) /bin/sh
at>halt `-i -p
at>
job 6 at 2004-01-01 17:35

此時實際上就已經進入Linux系統的Shell,並且編寫一個最簡單程式:halt -i -p。上面Shell中的文本結束符號表示按“Ctrl+D”組合鍵關閉命令,提交任務退出Shell。“Job 6 at 2004-01-01 17:35”表示系統接受第6個at命令,在“2004-01-01 17:35”時執行命令:先把所有網絡相關的裝置停止,關閉系統後關閉電源。

3.用crontab命令實現每天定時的病毒掃描
前面已經介紹了一個簡單的crontab命令操作,這裡看一些更重要的操作。

(1)建立一個檔案,檔案名稱自己設定,假設為caoproject:
#crontab -e

(2)檔案內容如下:
05 09 * * * antivir
用vi編輯後存盤退出。antivir是一個查殺Linux病毒的軟體,當然需要時先安裝在系統中。

(3)使用crontab命令添加到任務串列中:
#crontab caoproject
這樣系統內所有用戶在每天的9點05分會自動進行病毒掃描。

4.用kill使修改的配置檔案馬上生效
Windows用戶一般都知道,重要配置檔案修改後往往都要重新啟動計算機才能使修改生效。而Linux由於採用了模塊化設計,可以自己根據需要實時設定服務。這裡以網絡服務inetd為例介紹一些操作技巧。

inetd 是一個監聽守護行程,監聽與提供互聯網服務行程(如rlogin、telnet、ftp、rsh)進行連接的要求,並擴展所需的服務行程。預設情況下,inetd監聽的這些daemon均列於/etc /inetd.conf檔案中。編輯/etc/inetd.conf檔案,可以改變inetd啟動服務器守護行程的選項,然後驅使inetd以 SIGHUP(signal 1)向當前的inetd行程發送信號,使inetd重讀該檔案。這一過程由kill命令來實現。
用vi或其它編輯器修改inetd.conf後,首先使用下麵命令:
#ps -ef |grep inetd

上面代碼表明查詢inetd.conf的行程號(PID),這裡假設是1426,然後使用下麵命令:
# kill -1426 inetd
這樣配置檔案就生效了。

這一講介紹的系統管理命令都是比較重要的,特別是crontab命令和quota命令使用起來會有一定難度,需要多做一些練習。另外,使用kill命令要註意“-9“這個引數,練習時最好不要運行一些重要的程式。

以上為Linux必學的60個命令之前4類命令介紹,下文待續。

Linux的命令列方式功能強大,如果熟練掌握了Linux的常用命令,往往只需要通過各種技巧就可以組合構成一條複雜的命令,從而完成用戶任務。Linux系統中的命令實在是太多了,不可能像在MS DOS中把所有的命令及引數都記住。

Linux系統提供了一些方法,比如可以通過“help”和“man”來查詢名令。


更多Linux好文請點擊【閱讀原文】哦

↓↓↓

赞(0)

分享創造快樂