Linux必學的62條命令 (1)

  Linux必學的62條命令

  Linux提供了大量的命令,利用它可以有效地完成大量的工作,如磁盤操作、文件存取、目錄操作、進程管理、文件權限設定等。所以,在Linux系統上工作離不開使用系統提供的命令。要想真正理解Linux系統,就必須從Linux命令學起,通過基礎的命令學習可以進一步理解Linux系統。不同 Linux發行版的命令數量不一樣,但Linux發行版本最少的命令也有200多個。其中最常用的有62條。其中*表示必須掌握,**表示必須熟練掌握。

  目錄

  目錄 1

  1、安裝和登錄命令 3

  (1)login 3

  (2)shutdown * 4

  (3)reboot * 4

  (4)install * 4

  (5)mount * 5

  (6)umount * 6

  (7)exit * 7

  (8)last 7

  動手練習1 7

  小知識:Linux命令與Shell 8

  2、文件操作 8

  (9)cd ** 9

  (10)名稱:cut 9

  (11)file 9

  (12)mkdir * 10

  (13)grep * 10

  (14)dd 11

  (15)find ** 12

  (16)locate 13

  (17)mv ** 14

  (18)cp ** 14

  (19)vi ** 14

  (20)ls ** 15

  (21)diff * 16

  (22)cmp 17

  (23)cat * 17

  (24)ln * 18

  動手練習2 18

  3、系統管理相關命令 19

  (25)df * 19

  (26)top * 20

  (27)free * 21

  (28)quota 22

  (29)at 23

  (30)lp 23

  (31)useradd 24

  (32)groupadd 24

  (33)kill ** 25

  (34)crontab 26

  動手練習3 27

  4、網絡命令 28

  (35)ifconfig 28

  (36)ip 29

  (37)ping * 29

  (38)netstat * 30

  (39)telnet * 31

  (40)ftp * 32

  (41)route * 33

  (42)rlogin 33

  (43)rcp 34

  (44)finger 34

  (45)mail * 35

  (46)nslookup 35

  動手練習4 36

  5、系統安全相關命令 37

  (47)passwd * 37 (48)su ** 38 (49)umask 38 (50)chgrp 39 (51)chmod ** 40 (52)chown ** 41 (53)touch 42 (54)split 43 (55)ps ** 43 (56)who * 44 動手練習5 45

  6、其它 46

  (57)tar ** 46

  (58)unzip * 47

  (59)gunzip * 48

  (60)unarj * 49

  (61)man ** 49

  (62)clear ** 50

  動手練習6 50

   1、安裝和登錄命令

  
(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後輸入賬戶密碼,即可登錄系統。出於安全考慮,輸入賬戶密碼時字符不會在屏幕上回顯,光標也不移動。

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

  [root@localhost 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”鍵來訪問前六個虛擬控制檯。虛擬控制檯最有用的是,當一個程序出錯造成系統死鎖時,可以切換到其它虛擬控制檯工作,關閉這個程序。

  (2)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指令會被凍結,即新的用戶不能再登錄。

  (3)reboot *

  1.作用

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

  2.格式

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

  3.主要參數

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

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

  -d: 不把記錄寫到/var/log/wtmp文件裏(-n這個參數包含了-d)。

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

  (4)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:顯示版本信息並離開。

  (5)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除外。

  (6)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來卸裝它。僅當無用戶正在使用光盤時,該命令纔會成功。該命令包括了將帶有當前工作目錄當作該光盤中的目錄的終端窗口。

  (7)exit *

  1.作用

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

  2.格式

  exit

  3.參數

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

  (8)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:顯示系統關閉、用戶登錄和退出的歷史。

  動手練習1

  上面介紹了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等。

  2、文件操作

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

  (9)cd **

  使用權限 : 所有使用者

  使用方式 : cd [dirName]

  說明 : 變換工作目錄至 dirName。 其中 dirName 表示法可爲絕對路徑或相對路徑。若目錄名稱省略,則變換至使用者的 home directory (也就是剛 login 時所在的目錄)。

  另外,"~" 也表示爲 home directory 的意思,"." 則是表示目前所在的目錄,".." 則表示目前目錄位置的上一層目錄。

  範例 : 跳到 /usr/bin/ :

  cd /usr/bin

  跳到自己的 home directory :

  cd ~

  跳到目前目錄的上上兩層 :

  cd ../..

  (10)名稱:cut

  使用權限:所有使用者

  用法:cut -cnum1-num2 filename

  說明:顯示每行從開頭算起 num1 到 num2 的文字。

  範例:

  shell>> cat example

  test2

  this is test1

  shell>> cut -c0-6 example ## print開頭算起前 6 個字元

  test2

  this i

  (11)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命令不能探測包括圖形、音頻、視頻等多媒體文件類型。

  (12)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 (13)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-9]\{3\}含義是任意數字出現3次,後跟句點,接着是任意數字出現3次。

  $grep '[0-9 ]\{3 \}\.[0-9]\{3\}' ipfile

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

  (14)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命令將該內核寫入軟盤。

  (15)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

  (16)locate

  使用權限:所有使用者

  使用方式: locate [-q] [-d ] [--database=]

  locate [-r ] [--regexp=]

  locate [-qv] [-o ] [--output=]

  locate [-e ] [-f ] <[-l ] [-c]

  <[-U ] [-u]>

  locate [-Vh] [--version] [--help]

  說明:

  locate讓使用者可以很快速的搜尋檔案系統內是否有指定的檔案。其方法是先建立一個包括系統內所有檔案名稱及路徑的資料庫,之後當尋找時就只需查詢這個資料庫,而不必實際深入檔案系統之中了。

  在一般的 distribution 之中,資料庫的建立都被放在 contab 中自動執行。一般使用者在使用時只要用

  # locate your_file_name

  的型式就可以了。 參數:

  -u -U建立資料庫,-u 會由根目錄開始,-U 則可以指定開始的位置。

  -e將排除在尋找的範圍之外。

  -l如果是 1.則啓動安全模式。在安全模式下,使用者不會看到權限無法看到的檔案。這會始速度減慢,因爲 locate 必須至實際的檔案系統中取得檔案的權限資料。

  -f將特定的檔案系統排除在外,例如我們沒有到理要把 proc 檔案系統中的檔案放在資料庫中。

  -q安靜模式,不會顯示任何錯誤訊息。

  -n至多顯示 個輸出。

  -r使用正規運算式做尋找的條件。

  -o指定資料庫存的名稱。

  -d指定資料庫的路徑

  -h顯示輔助訊息

  -v顯示更多的訊息

  -V顯示程式的版本訊息範例:

  locate chdrv :尋找所有叫 chdrv 的檔案

  locate -n 100 a.out :尋找所有叫 a.out 的檔案,但最多隻顯示 100 個

  locate -u :建立資料庫

  (17)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

  (18)cp **

  cpmv基本相同,只不過前者是拷貝,後者是移動。

  (19)vi **

  vi

  vi命令是unix下常用而重要命令,可在全屏幕方式下編輯一個或多個文件。若在vi執行時

  沒有指定一個文件,那麼vi命令會自動產生一個無名的空的工作文件。若指定的文件不存在,

  那麼就按指定的文件名創建一個新的文件。若對文件的修改不保存的話,v i命令並不改變原

  來文件的內容。

  注意:vi命令並不鎖住所編輯的文件,因此多個用戶可能在同時編輯一個文件,那麼最後

  保存的文件版本將被保留。

  下面是vi命令使用的一些選項及含義:

  -c sub-command 在對指定的文件編輯前,先執行指定的命令 sub-command .

  -r filename 恢復指定的文件filename .

  -R 將指定的文件以只讀的方式放入編輯器中,這樣不會保存對文件的任何修改。

  -y number 將編輯窗口的大小設爲number行。

  下面是vi編輯所處的三種模式:

  .命令模式進入vi時所處的模式。在此模式下用戶可輸入各種子命令對進行*作,如刪除行、

  粘貼行、移向下一個字、移向不同行等。

  .文本輸入模式在此模式下可以修改一行的內容並增添新行。在命令模式下鍵入a 、i 或

  c鍵可進入文本輸入模式,按Escape鍵可返回命令模式。

  .命令項模式在此模式下,可以通過子命令輸入更多的參數。如:w子命令要求輸入一文件名,

  "/"子命令要求輸入一個查找項。用戶使用Escape鍵返回命令模式,命令模式下按:進入命令項模式。

  文本輸入模式下用來輸入文本的子命令(用戶可在任何時候按Escape返回到命令模式):

  a 在光標之後開始輸入文本。

  i在光標之前開始輸入文本。

  命令項模式:

  :w 回寫修改後的文件。

  :w filename 當filename不存在時,把修改後的文件存爲文件filename ,當文件filename

  存在時,報錯。

  !w filename 如果文件filename存在時,把修改後的文件保存爲文件filename .

  :q退出vi ,若用戶對編輯的文件有所修改,系統不會讓用戶使用q命令退出。

  :q!退出vi而不管是否對文件有改動。

  cat cd

  chmod chown

  cp cut

  (20)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:加上文件類型的指示符號 (*/=@| 其中一個)。

  -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:加上文件類型的指示符號 (/=@| 其中一個)。

  -Q, --quote-name:將項目名稱括上雙引號。

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

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

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

  4.應用舉例

  ls命令是Linux系統使用頻率最多的命令,它的參數也是Linux命令中最多的。使用ls命令時會有幾種不同的顏色,其中藍色表示是目錄,綠色表示是可執行文件,紅色表示是壓縮文件,淺藍色表示是鏈接文件,加粗的黑色表示符號鏈接,灰色表示是其它格式文件。ls最常使用的是ls- l,命令執行後,文件類型開頭是由10個字符構成的字符串。其中第一個字符表示文件類型,它可以是下述類型之一:-(普通文件)、d(目錄)、l(符號鏈接)、b (塊設備文件)、c(字符設備文件)。後面的9個字符表示文件的訪問權限,分爲3組,每組3位。第一組表示文件屬主的權限,第二組表示同組用戶的權限,第三組表示其他用戶的權限。每一組的三個字符分別表示對文件的讀(r)、寫(w)和執行權限(x)。對於目錄,表示進入權限。s表示當文件被執行時,把該文件的UID 或GID賦予執行進程的UID(用戶ID)或GID(組 ID)。t表示設置標誌位(留在內存,不被換出)。如果該文件是目錄,那麼在該目錄中的文件只能被超級用戶、目錄擁有者或文件屬主刪除。如果它是可執行文件,那麼在該文件執行後,指向其正文段的指針仍留在內存。這樣再次執行它時,系統就能更快地裝入該文件。接着顯示的是文件大小、生成時間、文件或命令名稱。

 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章