Linux系統中除進程以外的一切皆是文件,爲了便於文件的管理,Linux 還引入了目錄(有時亦被稱爲文件夾)這一律念。目錄使文件可被分類管理,且目錄的引用使 Linux 的文件系統造成一個層級結構的目錄樹。下圖所示的是普通 Linux 系統的頂層目錄結構,其中 /dev 是存放了設備相關文件的目錄。node
[root@CentOS7 data]#tree -L 1 / / 根目錄 ├── bin -> usr/bin 存放用戶二進制文件 ├── boot 存放內核引導配置文件 ├── data 存放數據文件 ├── dev 存放設備文件 ├── etc 存放系統配置文件 ├── home 用戶的家目錄 ├── lib -> usr/lib 動態共享庫 ├── lib64 -> usr/lib64 專用於x86_64系統上的輔助共享庫文件存放位置 ├── media 可卸載存儲介質掛載點 ├── mnt 文件系統臨時掛載點 ├── opt 附加的應用程序包 ├── proc 系統內存的映射文件,提供內核與進程信息 ├── root root用戶的家目錄 ├── sbin -> usr/sbin 存放系統二進制文件 ├── srv 存放服務相關數據 ├── sys sys 虛擬文件系統掛載點 ├── tmp 存放臨時文件 ├── usr 存放用戶應用程序 └── var 存放郵件、系統日誌等變化文件
Inode:文件都有文件名與數據,在 Linux 上被分紅兩個部分:用戶數據 (user data) 與元數據 (metadata)。用戶數據,即文件數據塊 (data block),數據塊是記錄文件真實內容的地方;而元數據則是文件的附加屬性,如文件大小、建立時間、全部者等信息。在 Linux 中,元數據中的 inode 號(inode 是文件元數據的一部分但其並不包含文件名,inode 號即索引節點號)纔是文件的惟一標識而非文件名。文件名僅是爲了方便人們的記憶和使用,系統或程序經過 inode 號尋找正確的文件數據塊。下圖展現了程序經過文件名獲取文件內容的過程。linux
filename ===> metadata ===> userdata
爲解決文件的共享使用,Linux 系統引入了兩種連接:硬連接 (hard link) 與軟連接(又稱符號連接,即 soft link 或 symbolic link)。連接爲 Linux 系統解決了文件的共享使用,還帶來了隱藏文件路徑、增長權限安全及節省存儲等好處。若一個 inode 號對應多個文件名,則稱這些文件爲硬連接。
因爲硬連接是有着相同 inode 號僅文件名不一樣的文件,所以硬連接存在如下幾點特性:
文件有相同的 inode 及 data block;
只能對已存在的文件進行建立;
不能交叉文件系統進行硬連接的建立;
不能對目錄進行建立,只可對文件建立;
刪除一個硬連接文件並不影響其餘有相同 inode 號的文件git
建立硬連接:ln filename linkname
軟連接與硬連接不一樣,若文件用戶數據塊中存放的內容是另外一文件的路徑名的指向,則該文件就是軟鏈接。軟連接就是一個普通文件,只是數據塊內容有點特殊。軟連接有着本身的 inode 號以及用戶數據塊。所以軟連接的建立與使用沒有相似硬連接的諸多限制:
軟連接有本身的文件屬性及權限等;
可對不存在的文件或目錄建立軟連接;
軟連接可交叉文件系統;
軟連接可對文件或目錄建立;
建立軟連接時,連接計數 i_nlink 不會增長;
刪除軟連接並不影響被指向的文件,但若被指向的原文件被刪除,則相關軟鏈接被稱爲死連接(即 dangling link,若被指向路徑文件被從新建立,死連接可恢復爲正常的軟連接)。安全
建立軟鏈接:ln -s filename linkname
-:常規文件;即f;
d: directory,目錄文件;
b: block device,塊設備文件,支持以「block」爲單位進行隨機訪問
c:character device,字符設備文件,支持以「character」爲單位進行線性訪問
major number:主設備號,用於標識設備類型,進而肯定要加載的驅動程序
minor number:次設備號,用於標識同一類型中的不一樣的設備;
l:symbolic link,符號連接文件;
p: pipe,命名管道;
s: socket,套接字文件;bash
[root@CentOS7 ~]#path=/etc/sysconfig/network-scripts/ifcfg-ens33 [root@CentOS7 ~]#basename $path ifcfg-ens33 [root@CentOS7 ~]#dirname $path /etc/sysconfig/network-scripts
[root@CentOS7 ~]#stat /etc/passwd File: ‘/etc/passwd’ Size: 2259 Blocks: 8 IO Block: 4096 regular file Device: 802h/2050d Inode: 135106383 Links: 1 Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root) Context: system_u:object_r:passwd_file_t:s0 Access: 2019-03-15 20:10:04.192015011 +0800 Modify: 2019-03-11 17:01:29.151074420 +0800 Change: 2019-03-11 17:01:29.151074420 +0800 Birth: -
格式:touch [OPTION]... FILE...
-a 僅改變 atime和ctime
-m 僅改變 mtime和ctime
-t [[CC]YY]MMDDhhmm[.ss]
指定atime和mtime的時間戳
-c 若是文件不存在,則不予建立app
* 匹配任意長度的任意字符
? 匹配任意單個字符
[] 匹配指定範圍的任意單個字符
有如下幾種經常使用特殊格式:
[a-z], [A-Z], [0-9], [a-z0-9],[a-zA-Z]
[[:upper:]]:全部大寫字母
[[:lower:]]:全部小寫字母
[[:alpha:]]:全部字母
[[:digit:]]:全部數字
[[:alnum:]]:全部的字母和數字
[[:space:]]:全部空白字符
[[:punct:]]:全部標點符號
[^] 匹配指定範圍外的任意單個字符
例: [^0-9], [^a-z]
實例:
顯示/var目錄下全部以l開頭,以一個小寫字母結尾,且中間出現一位任意字符的文件或目錄;socket
[root@CentOS7 ~]#ls -ld /var/l?[[:lower:]] [root@CentOS7 ~]#ls -ld /var/l?[a-z]
顯示/etc目錄下,以任意一位數字開頭,且以非數字結尾的文件或目錄;ide
[root@CentOS7 ~]#ls -ld /etc/[0-9]*[^0-9]
顯示/etc目錄下,以非字母開頭,後面跟一個字母及其它任意長度任意字符的文件或目錄;spa
[root@CentOS7 ~]#ls -ld /etc/[^[:alpha:]][[:alpha:]]*
複製/etc目錄下,全部以m開頭,以非數字結尾的文件或目錄至/data/testdir目錄;日誌
[root@CentOS7 data]#cp -rv /etc/m*[^0-9] /data/testdir
複製/usr/share/man目錄下,全部以man開頭,後跟一個數字結尾的文件或目錄至/data/man/目錄下;
[root@CentOS7 data]#cp -rv /usr/share/man/man[0-9] /data/man
複製/etc目錄下,全部以.conf結尾,且以m,n,r,p開頭的文件或目錄至/data/conf.d/目錄下;
[root@CentOS7 data]#cp -rv /etc/[mnrp]*.conf /data/conf.d
顯示root目錄下的隱藏文件或目錄
[root@CentOS7 ~]#ls -ad /root/.[^.]*
顯示/etc目錄下的非隱藏目錄
[root@CentOS7 ~]#ls -d /etc/[^.]*/
語法格式:cp [OPTION]... 源文件 目標文件
-v:顯示覆制過程;
-i:交互式複製,即覆蓋以前提醒用戶確認;
-f:強制覆蓋目標文件;
-r, -R:遞歸複製目錄;
-d:複製符號連接文件自己,而非其指向的源文件;
-a:-dR --preserve=all, archive,用於實現歸檔;
--preserv=
mode:權限
ownership:屬主和屬組
timestamps: 時間戳
context:安全標籤
xattr:擴展屬性
links:符號連接
all:上述全部屬性
實例:
一、定義別名命令baketc,天天將/etc/目錄下全部文件,備份到/data獨立的子目錄下,並要求子目錄格式爲 backupYYYY-mm-dd,備份過程可見
[root@CentOS7 ~]#alias baketc="cp -av /etc/ /data/backup`date +%F`"
二、建立/dat/app/rootdir目錄,並複製/root下全部文件到該目錄內,要求保留原有權限(-p)
[root@CentOS7 ~]#cp -rvp /root/* /data/app/rootdir/
語法格式:mv [option]... filename
i: 交互式
f: 強制
實例:將目錄/data/testdir更名爲/data/dir1
[root@CentOS7 data]#mv /data/testdir/ /data/dir1
將文件/data/a.txt 移動至用戶gong的家目錄
[root@CentOS7 data]#mv /data/a.txt /home/gong
語法格式:rm [OPTION]... FILE...
i: 交互式
f: 強制
r: 遞歸刪除
實例:刪除目錄/data/app/rootdir下的全部文件
[root@CentOS7 app]#rm -rf /data/app/rootdir/
建立目錄:mkdir
語法格式:mkdir [OPTION]... dir
-p: 自動按需建立父目錄
-v: verbose,顯示詳細過程
-m: MODE 建立時直接給定權限
注意:路徑基名方爲命令的做用對象;基名以前的路徑必須得存在;
刪除空目錄:rmdir
語法格式:rmdir [OPTION]... dir
-p:刪除某目錄後,若是其父目錄爲空,則一併刪除之;
-v: 顯示過程;
查看目錄樹:tree (須要提早安裝tree程序包)
語法格式:tree [OPTION]...
-d: 只顯示目錄
-L level:指定顯示的層級數目
-P pattern: 只顯示由指定pattern匹配到的路徑
實例:
如何建立/data/x/y1, /data/x/y2, /data/x/y1/a, /data/x/y1/b?
[root@CentOS7 data]#mkdir -pv /data/x/{y1/{a,b},y2}/ root@CentOS7 data]#tree . └── x ├── y1 │ ├── a │ └── b └── y2 5 directories, 0 files
如何建立a_c, a_d, b_c, b_d;
[root@CentOS7 data]#mkdir -v {a,b}_{c,d} //交叉建立目錄 mkdir: created directory ‘a_c’ mkdir: created directory ‘a_d’ mkdir: created directory ‘b_c’ mkdir: created directory ‘b_d’ [root@CentOS7 data]#tree . ├── a_c ├── a_d ├── b_c └── b_d 4 directories, 0 files [root@CentOS7 data]#rmdir -pv {a,b}_{c,d} //交叉刪除 rmdir: removing directory, ‘a_c’ rmdir: removing directory, ‘a_d’ rmdir: removing directory, ‘b_c’ rmdir: removing directory, ‘b_d’