我們都知道,在Linux系統中,基本上任何我們需要做的事都可以通過輸入命令來完成,所以在Linux系統中命令非常的多,我們不可能也沒必要記住所有的這些命令,但是對於一些常用的命令我們還是必須要對其了如指掌的。
當然,即使這樣,我們需要掌握的常用的命令也有百余條之多,我們難道就專門針對這百余條常用的命令來對其進行死記硬背嗎?就像在學java時,我們學習其23種設計模式一樣,我們不能單純為了只是為了學習那23種設計模式而去學習,我們更重要的是學習這些模式,然后在實際項目中多去用它。在學習23種設計模式時,當然不推薦花幾天時間就死死地抱着那23種模式去硬啃,這樣不科學而且學完后又容易忘。所以我之前在學習設計模式時,是根據在學習java的每個知識點時需要用到了什么模式,然后再去有針對性的學習一種設計模式。例如我在學習集合時,對於Set(TreeSet)、Map(TreeMap)這塊,其用到了策略模式,所以此時我就去單學習策略模式,然后再回過頭來看一下集合這塊它是怎么使用策略模式的。又比如在學習Swing/AWT時,我們用到了觀察者模式,所以此時我就先學習了觀察者模式的定義,然后實現自己的觀察者模式,最后再反過來細看一下Swing這塊是怎么運用觀察者模式的。對於我們在學習到某個知識點時用到了什么知識,然后我們再去有針對性的學習,我認為這種方式是很好的,比盲目的抱着一本書從頭到尾學個透要記得更牢、學的更好。
對於Linux命令這塊地學習,我也是通過這種方式來學習的,對於在學習一個知識點時,我們用到了哪些常用的命令,我就對這些命令進行詳細的學習。所以從這篇隨筆開始,將會根據我學習Linux的計划來記錄在學習中所用到的一些常用的Linux命令。這篇隨筆剛好是在學習Linux文件和目錄管理時寫的,所以本篇隨筆將會詳細記錄一下與 Linux文件和目錄管理 相關的一些重要命令。廢話就不多說了,直接進入這一塊的常用命令的學習!!!!
一、目錄與路徑
1.相對路徑與絕對路徑
因為我們在Linux系統中,常常要涉及到目錄的切換,所以我們必須要了解 "路徑" 以及 "相對路徑" 與 "絕對路徑" 的概念。
在之前的學習中,就反復的強調了Linux的目錄是 "樹狀目錄" 。假設我們需要在任意一個目錄下切換到另一個目錄下,通常是使用的是 cd 這個命令,此時在寫切換的目錄名時就有兩種書寫方式,也就是我們常說的使用 "相對路徑" 與 "絕對路徑" 來書寫
- 絕對路徑:路徑的寫法【一定由根目錄 / 寫起】,例如: /usr/share/doc 這個目錄。
- 相對路徑:路徑的寫法【不是由 / 寫起】,例如由 /usr/share/doc 要到 /usr/share/man 底下時,可以寫成: 【cd ../man】這就是相對路徑的寫法。相對路徑意指相對於當前的工作目錄
我們知道,在Linux的系統中完整的文件路徑名的長度最大可以達到4096個字符,所以一個文件路徑名太長的話,此時寫絕對路徑時就非常的麻煩,而且可能寫錯,所以此時選擇使用相對路徑來寫就會簡單一些。
但是,對於文件的正確性來說,絕對路徑是比較好的。當我們在寫 shell scripts 時,請務必使用絕對路徑。雖然可能寫絕對路徑會稍顯麻煩,但是這種寫法是絕對不會有問題的。
2.cd (切換目錄)
這個命令應該是Linux中用的最頻繁的一個命令之一了,因為我們經常需要進行目錄的切換。在詳解這個命令之前,首先得補充一個重要的知識,就是我們常用的一些比較特殊的目錄:
. 代表當前目錄 .. 代表上一層目錄 - 代表前一個工作目錄 ~ 代表【目前用戶身份】所在的自家目錄 ~account 代表 account 這個用戶的自家家目錄
我們通過實例來看一下這些特殊命令的使用方法:
[root@xiaoluo ~]# cd /home # 此時我們進入到了home目錄下 [root@xiaoluo home]# cd . # .表示當前目錄,所以當前還是在home目錄下 [root@xiaoluo home]# cd .. # ..表示上一層目錄,所以此時就進入到了 / 目錄下
[root@xiaoluo /]# cd ~
# ~表示【目前用戶身份】所在的自家目錄,當前用戶就是root,所以就進入到了root這個目錄下
[root@xiaoluo ~]# cd ~xiaoluo
# ~account表示 account 這個用戶的自家家目錄 ,我如果想進入 xiaoluo 這個用戶的主目錄,輸入 cd ~xiaoluo即可
[root@xiaoluo xiaoluo]# cd -
/root
# -表示前一個工作目錄,我們的前一個工作目錄就是在root下,所以此時又會進入到root這個目錄下
[root@xiaoluo ~]# cd ../usr
# 如果我們需要進入到usr目錄下,這里可以寫成相對路徑形式也可以寫成絕對路徑形式
[root@xiaoluo usr]#
通過上面的幾個實例我們應該對cd 這個命令有了深入的了解了,而且也知道了那幾個特殊目錄所代表的含義。
3.pwd (顯示當前所在的目錄)
這個命令對於我們來說也是一個很重要的命令,因為在Linux下我們都是通過在命令行輸入命令,所有如果進入到了一個目錄下,就不會像windows那樣直觀的顯示出當前所在的路徑,此時我們就可以輸入 pwd 這個命令來顯示我們當前所在的目錄。
[root@xiaoluo ~]# pwd [-P] 參數: -P :顯示出確實的路徑,而非使用鏈接 (link) 路徑。(P是大寫)
范例: [root@xiaoluo ~]# pwd /root <== 顯示出當前所在的目錄
[root@xiaoluo ~]# cd /var/mail [root@xiaoluo mail]# pwd /var/mail [root@xiaoluo mail]# pwd -P /var/spool/mail <== 怎么回事?有沒有加 -P 差很多
[root@xiaoluo mail]# ls -l /var/mail lrwxrwxrwx. 1 root root 10 3月 30 10:37 mail -> spool/mail # 看到這里應該知道為啥了吧?因為 /var/mail 是連結文件,連結到 /var/spool/mail # 所以,加上 pwd -P 的參數后,會不以連結文件的數據顯示,而是顯示正確的完整路徑!
4.mkdir (建立新目錄)
[root@xiaoluo ~]# mkdir [-mp] 目錄名稱 參數: -m :配置文件目錄的權限!我們可以自己設定自己想要的權限,而不需要使用umask定義的默認權限 -p :幫助你直接將所需要的目錄遞歸建立起來! 范例: [root@xiaoluo ~]# cd /home [root@xiaoluo home]# mkdir test <== 建立一名為 test 的新目錄 [root@xiaoluo home]# mkdir test1/test2/test3/test4 mkdir: 無法創建目錄"test1/test2/test3/test4": 沒有那個文件或目錄
[root@linux tmp]# mkdir -p test1/test2/test3/test4 # 加了這個 -p 的參數,可以自行幫我們建立多層目錄! [root@xiaoluo home]# mkdir -p test1/test2/test3/test4 [root@xiaoluo home]# mkdir -m 711 test2 [root@xiaoluo home]# ls -l drwxr-xr-x. 2 root root 4096 4月 21 13:08 test drwxr-xr-x. 3 root root 4096 4月 21 13:10 test1 drwx--x--x. 2 root root 4096 4月 21 13:11 test2 # 仔細看上面的權限部分,如果沒有加上 -m 來強制設定屬性,系統會使用默認屬性。如果加上了-m 這個參數,我們就可以自己定義權限了
5.rmdir (刪除"空"目錄)
[root@xiaoluo ~]# rmdir [-p] 目錄名稱 參數: -p :連同上層『空的』目錄也一起刪除 范例: [root@xiaoluo home]# ls -l drwxr-xr-x. 2 root root 4096 4月 21 13:08 test drwxr-xr-x. 3 root root 4096 4月 21 13:10 test1 drwx--x--x. 2 root root 4096 4月 21 13:11 test2 [root@xiaoluo home]# rmdir test [root@xiaoluo home]# rmdir test1 rmdir: 刪除 "test1" 失敗: 目錄非空 [root@xiaoluo home]# rmdir -p test1/test2/test3/test4/ [root@xiaoluo home]# ls -l drwx--x--x. 2 root root 4096 4月 21 13:11 test2
# 利用 -p 這個參數,立刻就可以將 test1/test2/test3/test4 一次刪除~ # 不過要注意的是,這個 rmdir 僅能【刪除空的目錄】!
二、管理文件與目錄
在了解目錄與路徑之后,我們繼續學習管理文件與目錄的一些命令!文件與目錄的管理上,不外乎【顯示屬性】、【拷貝】、【刪除文件】及【移動文件或目錄』】等等,由於文件與目錄的管理在 Linux 當中是很重要的, 尤其是每個人自己自家目錄的數據也都需要注意管理!
1.ls (查看文件和目錄)
[root@xiaoluo ~]# ls [-aAdfFhilRS] 目錄名稱 [root@xiaoluo ~]# ls [--color={none,auto,always}] 目錄名稱 [root@xiaoluo ~]# ls [--full-time] 目錄名稱 參數: -a :全部的文件,連同隱藏文件( 開頭為 . 的目錄) 一起列出來~ -A :全部的文件,連同隱藏文件,但不包括 . 與 .. 這兩個目錄,一起列出來~ -d :僅列出目錄本身,而不是列出目錄內的文件數據 -f :直接列出結果,而不進行排序 (ls 預設會以文件名排序!) -F :根據文件、目錄等信息,給予附加數據結構,例如: *:代表可執行文件; /:代表目錄; =:代表 socket 檔案; |:代表 FIFO 文件; -h :列出文件的打小(例如GB、KB等等) -i :列出 inode 位置,而非列出文件屬性; -l :長數據串行出,包含文件的屬性等等數據; -n :列出 UID 與 GID 而非使用者與群組的名稱 (UID與GID會在賬號管理提到!) -r :將排序結果反向輸出,例如:原本文件名由小到大,反向則為由大到小; -R :連同子目錄內容一起列出來; -S :以文件容量大小排序! -t :依時間排序 --color=never :不要依據文件特性給予顏色顯示; --color=always :顯示顏色 --color=auto :讓系統自行依據設定來判斷是否給予顏色 --full-time :以完整時間模式 (包含年、月、日、時、分) 輸出 --time={atime,ctime} :輸出 access 時間或 改變權限屬性時間 (ctime) 而非內容變更時間 (modification time)
在 Linux 系統當中,這個 ls 指令可能是最常被執行的命令!因為我們隨時都要知道文件或者是目錄的相關信息啊。 不過,我們 Linux 的文件所記錄的信息實在是太多了, ls 沒有需要全部都列出來呢, 所以,當輸入ls命令時,默認顯示的只有:非隱藏文件的文件名、 以文件名進行排序及文件名代表的顏色顯示;
[root@xiaoluo home]# ls -al ~ 總用量 216 dr-xr-x---. 31 root root 4096 4月 19 20:40 . dr-xr-xr-x. 26 root root 4096 4月 21 11:14 .. drwxr-xr-x. 2 root root 4096 3月 31 14:26 .abrt -rw-------. 1 root root 13062 4月 21 00:58 .bash_history -rw-r--r--. 1 root root 18 5月 20 2009 .bash_logout -rw-r--r--. 1 root root 176 5月 20 2009 .bash_profile -rw-r--r--. 1 root root 177 4月 8 22:43 .bashrc drwxr-xr-x. 4 root root 4096 4月 1 12:28 .cache drwxr-xr-x. 6 root root 4096 4月 1 12:26 .config -rw-r--r--. 1 root root 100 9月 23 2004 .cshrc drwx------. 3 root root 4096 3月 31 14:25 .dbus -rw-------. 1 root root 16 3月 31 14:26 .esd_auth drwx------. 4 root root 4096 4月 5 12:09 .gconf drwx------. 2 root root 4096 4月 5 18:56 .gconfd drwx------. 7 root root 4096 4月 1 12:28 .gnome2 drwx------. 2 root root 4096 4月 1 11:49 .gnome2_private drwxr-xr-x. 3 root root 4096 3月 31 14:26 .gnote drwx------. 2 root root 4096 4月 1 11:46 .gnupg drwxr-xr-x. 2 root root 4096 3月 31 14:26 .gstreamer-0.10 -rw-r--r--. 1 root root 160 4月 1 11:46 .gtk-bookmarks drwx------. 2 root root 4096 3月 31 14:25 .gvfs -rw-------. 1 root root 624 4月 1 11:46 .ICEauthority -rw-r--r--. 1 root root 785 4月 1 11:46 .imsettings.log drwx------. 3 root root 4096 4月 1 12:26 .kde -rw-------. 1 root root 46 4月 20 23:50 .lesshst drwxr-xr-x. 3 root root 4096 3月 31 14:25 .local drwxr-xr-x. 4 root root 4096 4月 1 11:49 .mozilla -rw-------. 1 root root 1711 4月 19 20:23 .mysql_history drwxr-xr-x. 2 root root 4096 3月 31 14:26 .nautilus drwx------. 2 root root 4096 3月 31 14:26 .pulse -rw-------. 1 root root 256 3月 31 14:25 .pulse-cookie -rw-------. 1 root root 3244 4月 1 12:34 .recently-used.xbel drwxr-xr-x. 3 root root 4096 3月 31 14:26 .redhat drwx------. 2 root root 4096 3月 31 14:25 .ssh drwxr-xr-x. 2 root root 4096 3月 30 11:20 .targetcli -rw-r--r--. 1 root root 129 12月 4 2004 .tcshrc drwx------. 3 root root 4096 4月 1 12:18 .thumbnails -rw-------. 1 root root 511 4月 5 00:04 .viminfo -rw-------. 1 root root 52 3月 31 14:18 .xauth58xele -rw-------. 1 root root 52 4月 19 19:34 .xauthAQSudj -rw-------. 1 root root 52 4月 1 20:09 .xauthFR3WoT -rw-------. 1 root root 52 3月 31 21:56 .xauthGPcuIJ -rw-------. 1 root root 52 3月 31 22:06 .xauthhgV2Ad -rw-------. 1 root root 0 3月 30 15:26 .Xauthority
2. cp (復制命令)
要復制文件,我們就要用到cp(copy)命令。不過cp命令的用途非常的廣泛,除了單純的復制之外,還可以建立連接文件(相當於windows下的快捷方式),比較兩個文件的新舊而予以更新,以及復制整個目錄等等。
[root@xiaoluo ~]# cp [-adfilprsu] 源文件(source) 目的文件(destination) [root@xiaoluo ~]# cp [options] source1 source2 source3 .... directory 參數: -a :相當於 -pdr 的意思; -d :若來源文件為鏈接文件的屬性(link file),則復制鏈接文件屬性而非檔案本身; -f :為強制 (force) 的意思,若有重復或其他疑問時,不會詢問使用者,而強制復制; -i :若目的文件(destination)已經存在時,在覆蓋時會先詢問是否真的動作! -l :進行硬式連結 (hard link) 的連結文件建立,而非復制文件本身; -p :連同文件的屬性一起復制過去,而非使用默認屬性; -r :遞歸持續復制,用於目錄的復制行為; -s :復制成為符號鏈接文件 (symbolic link),亦即『快捷方式』文件; -u :若 destination 比 source 舊才更新 destination ! 最后需要注意的,如果來源檔有兩個以上,則最后一個目的文件一定要是『目錄』
下面我們來寫一些實例來看一下cp命令的常用用法:
實例一:將家目錄下的 .bashrc 復制到 /tmp 下,並更名為 bashrc [root@xiaoluo home]# cd /tmp [root@xiaoluo tmp]# cp ~/.bashrc bashrc [root@xiaoluo tmp]# cp -i ~/.bashrc bashrc cp:是否覆蓋"bashrc"? n # 重復作兩次動作,由於 /tmp 底下已經存在 bashrc 了,加上 -i 參數, # 則在覆蓋前會詢問使用者是否確定!可以按下 n 或者 y ! # 但是,反過來說,如果不想要詢問時,則加上 -f 這個參數來強制直接覆蓋! 實例二:將 /var/log/wtmp 復制到 /tmp 底下 [root@xiaoluo tmp]# cp /var/log/wtmp . [root@xiaoluo tmp]# ls -l /var/log/wtmp wtmp -rw-rw-r--. 1 root utmp 204288 4月 21 11:22 /var/log/wtmp -rw-r--r--. 1 root root 204288 4月 21 13:33 wtmp # 注意到了嗎?!在不加任何參數的情況下,文件的所屬者會改變,連權限也跟着改變了
# 這是個很重要的特性!要注意!還有,連文件建立的時間也不一樣了! # 如果您想要將文件的所有特性都一起復制過來,可以加上 -a 參數即可!
[root@xiaoluo tmp]# cp -a /var/log/wtmp wtmp2
[root@xiaoluo tmp]# ls -l /var/log/wtmp wtmp2
-rw-rw-r--. 1 root utmp 204288 4月 21 11:22 /var/log/wtmp
-rw-rw-r--. 1 root utmp 204288 4月 21 11:22 wtmp2
# 此時我們看到在加上 -a 這個參數以后,文件的所有屬性都會被復制過來。
實例三:復制 /etc/ 這個目錄下的所有內容到 /tmp 底下
[root@xiaoluo tmp]# cp /etc/ /tmp
cp: 略過目錄"/etc/" -->> 如果我們復制的是目錄,此時必須要加上 -r 這個參數才行
[root@xiaoluo tmp]# cp -r /etc/ /tmp
# 還是要再次的強調! -r 是可以復制目錄,但是,檔案與目錄的權限會被改變
# 所以,也可以利用 cp -a /etc /tmp 來下達指令! 使用-a 參數相當於同時使用了 -pdr 參數
3.rm (刪除文件或目錄)
[root@xiaoluo ~]# rm [-fir] 文件或目錄 參數: -f :就是 force 的意思,強制移除; -i :互動模式,在刪除前會詢問使用者是否動作 -r :遞歸刪除!最常用在目錄的刪除了
下面我們通過一些實例來看一下rm命令的使用
[root@xiaoluo tmp]# rm bashrc rm:是否刪除普通文件 "bashrc"?y [root@xiaoluo tmp]# rm wtmp wtmp2 rm:是否刪除普通文件 "wtmp"?y rm:是否刪除普通文件 "wtmp2"?y
[root@xiaoluo tmp]# rm -rf etc/ -->> 這個就會強制將etc這個目錄以及里面的所有子目錄、文件刪除掉
4.mv (移動文件與目錄、文件重命名)
[root@xiaoluo ~]# mv [-fiu] source destination [root@xiaoluo ~]# mv [options] source1 source2 source3 .... directory 參數: -f :force 強制的意思,強制直接移動而不詢問; -i :若目標文件 (destination) 已經存在時,就會詢問是否覆蓋! -u :若目標文件已經存在,且 source 比較新,才會更新 (update)
實例一:復制一檔案,建立一目錄,將檔案移動到目錄中
[root@xiaoluo tmp]# cp ~/.bashrc bashrc
[root@xiaoluo tmp]# mkdir mvtest
[root@xiaoluo tmp]# mv bashrc mvtest/
[root@xiaoluo tmp]# cd mvtest/
[root@xiaoluo mvtest]# ls
bashrc
# 將某個檔案移動到某個目錄去,就是這樣做!
實例二:將剛剛的目錄名稱更名為 mvtest2
[root@xiaoluo tmp]# mv mvtest mvtest2 <== 這樣就更名了!
# 其實在 Linux 底下還有個命令令,名稱為 rename ,
# 該命令就是專門用來對文件或者目錄進行重命名的鎮明路!可以參閱 man rename 了解其更多的用法 !
5.basename (獲取路徑的文件名) dirname (獲取路徑的目錄名)
完整的文件名最長我們可以為4096個字符。那么我們怎么樣知道哪個代表的是文件名?哪個代表的是目錄名呢?其實我們通過斜線 / 就可以來分辨。當然Linux下的basename、dirname這兩個命令也可以幫助我們來獲得文件名和目錄名。例如:
[root@xiaoluo ~]# basename /etc/inittab inittab -->>這個就是我們的文件名
[root@xiaoluo ~]# dirname /etc/inittab /etc -->>這個就是我們的目錄名
三、查看文件內容
上面提到的一些命令例如ls 只是用來顯示文件的屬性與權限,或者移動與復制文件或目錄,那么我們如果想要查看文件里面的內容,又有哪些命令可以使用呢?
- cat 由第一行開始顯示文件內容
- tac 從最后一行開始顯示,可以看出 tac 是 cat 的倒着寫!
- nl 顯示的時候,連同行號一起輸出!
- more 一頁一頁的顯示文件內容
- less 與 more 類似,但是比 more 更好的是,他可以往前翻頁!
- head 只看頭幾行
- tail 只看最后幾行
- od 以二進制的方式讀取文件內容!
我們最常用的顯示文件內容的命令是cat、more以及less,這三個我們用的最多。
1.cat (concatenate)
[root@xiaoluo~]# cat [-AEnTv] 參數: -A :相當於 -vET 的整合參數,可列出一些特殊字符~ -E :將結尾的斷行字符 $ 顯示出來; -n :打印出行號; -T :將 [tab] 按鍵以 ^I 顯示出來; -v :列出一些看不出來的特殊字符
我們通過實例來看一下cat命令的常用使用方法:
[root@xiaoluo ~]# cat /etc/sysconfig/network NETWORKING=yes HOSTNAME=xiaoluo
[root@xiaoluo ~]# cat -n /etc/sysconfig/network
1 NETWORKING=yes
2 HOSTNAME=xiaoluo
[root@xiaoluo ~]# cat -A /etc/sysconfig/network
NETWORKING=yes$
HOSTNAME=xiaoluo$
# 在一般的環境中,打印出來的結果在有 [tab] 與空格鍵,其實看不出來,
# 那么使用 cat -A 時,會將 [tab] 按鍵以 ^I 顯示,而斷行字符也會顯示出來
# 最特殊的當然就是斷行字符了!這個段行字符在 Linux 與 Windows 是不一樣的。
# 在 Linux 是以 $ 為斷行字符,而在 Windows 則是以 ^M$ 為斷行字符。
2.tac (反向顯示)
[root@xiaoluo ~]# tac /etc/sysconfig/network HOSTNAME=xiaoluo NETWORKING=yes
tac是將cat反寫,所以它的功能就與cat相反, cat 是由【第一行到最后一行連續顯示在屏幕上】,而 tac 則是『【由最后一行到第一行反向在屏幕上顯示出來 】。
3.nl (顯示時添加行號)
[root@xiaoluo ~]# nl [-bnw] 文件 參數: -b :指定行號指定的方式,主要有兩種: -b a :表示不論是否為空行,也同樣列出行號; -b t :如果有空行,空的那一行不要列出行號; -n :列出行號表示的方法,主要有三種: -n ln :行號在屏幕的最左方顯示; -n rn :行號在自己字段的最右方顯示,且不加 0 ; -n rz :行號在自己字段的最右方顯示,且加 0 ; -w :行號字段的占用的位數。
我們通過實例來看下nl命令的用法:
[root@xiaoluo ~]# nl /etc/issue 1 CentOS release 6.4 (Final) 2 Kernel \r on an \m # 注意看,這個檔案其實有三行,第三行為空白(沒有任何字符), # 因為他是空白行,所以 nl 不會加上行號喔!如果確定要加上行號,可以這樣做: [root@xiaoluo ~]# nl -b a /etc/issue 1 CentOS release 6.4 (Final) 2 Kernel \r on an \m 3 [root@xiaoluo ~]# nl -b a -n rz /etc/issue 000001 CentOS release 6.4 (Final) 000002 Kernel \r on an \m 000003 # 自動在自己字段的地方補上 0 了 預設字段是六位數,如果想要改成 3 位數 可以加上 -w 這個參數
[root@xiaoluo ~]# nl -b a -n rz -w 3 /etc/issue 001 CentOS release 6.4 (Final) 002 Kernel \r on an \m 003
4.more (翻頁查看)
[root@xiaoluo ~]# more /etc/passwd root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin adm:x:3:4:adm:/var/adm:/sbin/nologin lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin sync:x:5:0:sync:/sbin:/bin/sync shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown halt:x:7:0:halt:/sbin:/sbin/halt mail:x:8:12:mail:/var/spool/mail:/sbin/nologin uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin operator:x:11:0:operator:/root:/sbin/nologin games:x:12:100:games:/usr/games:/sbin/nologin gopher:x:13:30:gopher:/var/gopher:/sbin/nologin ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin nobody:x:99:99:Nobody:/:/sbin/nologin dbus:x:81:81:System message bus:/:/sbin/nologin rpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin usbmuxd:x:113:113:usbmuxd user:/:/sbin/nologin abrt:x:173:173::/etc/abrt:/sbin/nologin pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin /nologin cimsrvr:x:134:134:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sb in/nologin --More--(36%)
在使用more命令時,我們通常可以使用以下一些快捷鍵來幫助我們
- 空格鍵 (space):代表向下翻一頁;
- Enter :代表向下翻【一行】;
- /字符串 :代表在這個顯示的內容當中,向下搜尋【字符串】;
- :f :立刻顯示出文件名以及目前顯示的行數;
- q :代表立刻離開 more ,不再顯示該文件內容。
5. less (翻頁查看)
[root@xiaoluo ~]# less /etc/passwd root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin adm:x:3:4:adm:/var/adm:/sbin/nologin lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin sync:x:5:0:sync:/sbin:/bin/sync shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown halt:x:7:0:halt:/sbin:/sbin/halt mail:x:8:12:mail:/var/spool/mail:/sbin/nologin uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin operator:x:11:0:operator:/root:/sbin/nologin games:x:12:100:games:/usr/games:/sbin/nologin gopher:x:13:30:gopher:/var/gopher:/sbin/nologin ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin nobody:x:99:99:Nobody:/:/sbin/nologin dbus:x:81:81:System message bus:/:/sbin/nologin rpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin usbmuxd:x:113:113:usbmuxd user:/:/sbin/nologin abrt:x:173:173::/etc/abrt:/sbin/nologin pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin/nologin cimsrvr:x:134:134:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin/nologin /etc/passwd
less的用法比more要更靈活,使用more命令時我們沒有辦法向前翻頁,只能往后看,而less命令可以通過(PageUp) (PageDown)來進行前后的翻頁查看文件。
less命令的一些常用快捷鍵操作如下:
- 空格鍵 :向下翻動一頁;
- [pagedown]:向下翻動一頁;
- [pageup] :向上翻動一頁;
- /字符串 :向下搜尋【字符串】的功能;
- ?字符串 :向上搜尋【字符串】的功能;
- n :重復前一個搜尋 (與 / 或 ? 有關!)
- N :反向的重復前一個搜尋 (與 / 或 ? 有關!)
- q :離開 less 這個程序;
6. head (取出前幾行)
[root@xiaoluo ~]# head [-n number] 文件 參數: -n :后面接數字,代表顯示幾行的意思
實例: [root@xiaoluo ~]# head /etc/man.config # 默認的情況中,顯示前面十行!若要顯示前 20 行,就得要這樣: [root@xiaoluo ~]# head -n 20 /etc/man.config
7.tail (取出后面幾行)
[root@xiaoluo ~]# tail [-n number] 文件 參數: -n :后面接數字,代表顯示幾行的意思 范例: [root@xiaoluo ~]#tail /etc/man.config # 默認的情況中,顯示最后的十行!若要顯示最后的 20 行,就得要這樣: [root@xiaoluo ~]# tail -n 20 /etc/man.config
8.od (查看非文本文件)
我們上面提到的一些命令,都是在查閱純文本檔 (ASCII 格式的檔案) 的內容。 那么萬一我們想要查閱非文本文件,舉例來說,例如 /usr/bin/passwd 這個執行檔的內容時, 又該如何去讀出信息呢?事實上,由於執行檔通常是 binary file ,使用上頭提到的指令來讀取他的內容時, 確實會產生類似亂碼的數據!那怎么辦?沒關系,我們可以利用 od 這個命令來進行查看!
[root@xiaoluo ~]# od [-t TYPE] 文件 參數: -t :后面可以接各種『類型 (TYPE)』的輸出,例如: a :利用默認的字符來輸出; c :使用 ASCII 字符來輸出 d[size] :利用十進制(decimal)來輸出數據,每個整數占用 size bytes ; f[size] :利用浮點數(floating)來輸出數據,每個數占用 size bytes ; o[size] :利用八進制(octal)來輸出數據,每個整數占用 size bytes ; x[size] :利用十六進制(hexadecimal)來輸出數據,每個整數占用 size bytes ; 范例: [root@xiaoluo ~]# od -t c /usr/bin/passwd 0000000 177 E L F 001 001 001 \0 \0 \0 \0 \0 \0 \0 \0 \0 0000020 002 \0 003 \0 001 \0 \0 \0 260 225 004 \b 4 \0 \0 \0 0000040 020 E \0 \0 \0 \0 \0 \0 4 \0 \0 \a \0 ( \0 0000060 035 \0 034 \0 006 \0 \0 \0 4 \0 \0 \0 4 200 004 \b 0000100 4 200 004 \b 340 \0 \0 \0 340 \0 \0 \0 005 \0 \0 \0 .....中間省略.......
使用這個命令,我們就可以將數據文件或者二進制文件的內容讀出來。
本篇隨筆主要記錄了與Linux文件和目錄管理相關的一些重要命令,由於時間關系,關於與Linux文件和目錄管理相關的一些重要命令還沒有記錄完,其他常見的一些命令例如 touch 、以及涉及到文件與目錄默認權限想過的umask命令將會在下一篇隨筆中記錄!!!!
小弟不才,如果本文能對大家有所幫助,希望大家慷慨的點擊一下推薦!!!