文件系統;inode;軟硬連接;文件通配符;文件管理命令:mkdir 、cp、rm、mv、touch
1、linux文件系統
Linux系統中除進程之外的一切皆是文件,為了便於文件的管理,Linux 還引入了目錄(有時亦被稱為文件夾)這一概念。目錄使文件可被分類管理,且目錄的引用使 Linux 的文件系統形成一個層級結構的目錄樹。下圖所示的是普通 Linux 系統的頂層目錄結構,其中 /dev 是存放了設備相關文件的目錄。
[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 存放郵件、系統日誌等變化文件
2、索引節點inode
Inode:文件都有文件名與數據,在 Linux 上被分成兩個部分:用戶數據 (user data) 與元數據 (metadata)。用戶數據,即文件數據塊 (data block),數據塊是記錄文件真實內容的地方;而元數據則是文件的附加屬性,如文件大小、創建時間、所有者等信息。在 Linux 中,元數據中的 inode 號(inode 是文件元數據的一部分但其並不包含文件名,inode 號即索引節點號)才是文件的唯一標識而非文件名。文件名僅是為了方便人們的記憶和使用,系統或程序通過 inode 號尋找正確的文件數據塊。下圖展示了程序通過文件名獲取文件內容的過程。
filename ===> metadata ===> userdata
3、硬鏈接和軟連接:
為解決文件的共享使用,Linux 系統引入了兩種鏈接:硬鏈接 (hard link) 與軟鏈接(又稱符號鏈接,即 soft link 或 symbolic link)。鏈接為 Linux 系統解決了文件的共享使用,還帶來了隱藏文件路徑、增加權限安全及節省存儲等好處。若一個 inode 號對應多個文件名,則稱這些文件為硬鏈接。
由於硬鏈接是有著相同 inode 號僅文件名不同的文件,因此硬鏈接存在以下幾點特性:
?文件有相同的 inode 及 data block;
?只能對已存在的文件進行創建;
?不能交叉文件系統進行硬鏈接的創建;
?不能對目錄進行創建,只可對文件創建;
?刪除一個硬鏈接文件並不影響其他有相同 inode 號的文件
創建硬鏈接:ln filename linkname
軟鏈接與硬鏈接不同,若文件用戶數據塊中存放的內容是另一文件的路徑名的指向,則該文件就是軟連接。軟鏈接就是一個普通文件,只是數據塊內容有點特殊。軟鏈接有著自己的 inode 號以及用戶數據塊。因此軟鏈接的創建與使用沒有類似硬鏈接的諸多限制:
?軟鏈接有自己的文件屬性及權限等;
?可對不存在的文件或目錄創建軟鏈接;
?軟鏈接可交叉文件系統;
?軟鏈接可對文件或目錄創建;
?創建軟鏈接時,鏈接計數 i_nlink 不會增加;
?刪除軟鏈接並不影響被指向的文件,但若被指向的原文件被刪除,則相關軟連接被稱為死鏈接(即 dangling link,若被指向路徑文件被重新創建,死鏈接可恢復為正常的軟鏈接)。
創建軟連接:ln -s filename linkname
2、Linux系統上的文件類型
-:常規文件;即f;
d: directory,目錄文件;
b: block device,塊設備文件,支持以“block”為單位進行隨機訪問
c:character device,字符設備文件,支持以“character”為單位進行線性訪問
major number:主設備號,用於標識設備類型,進而確定要加載的驅動程序
minor number:次設備號,用於標識同一類型中的不同的設備;
l:symbolic link,符號鏈接文件;
p: pipe,命名管道;
s: socket,套接字文件;
3、基名bashname 目錄名dirname
[root@CentOS7 ~]#path=/etc/sysconfig/network-scripts/ifcfg-ens33
[root@CentOS7 ~]#basename $path
ifcfg-ens33
[root@CentOS7 ~]#dirname $path
/etc/sysconfig/network-scripts
4、查看文件狀態stat
[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: -
5、創建空文件和刷新時間touch
格式:touch [OPTION]... FILE...
-a 僅改變 atime和ctime
-m 僅改變 mtime和ctime
-t [[CC]YY]MMDDhhmm[.ss]
指定atime和mtime的時間戳
-c 如果文件不存在,則不予創建
6、文件通配符globbing
?* 匹配任意長度的任意字符
?? 匹配任意單個字符
?[] 匹配指定範圍的任意單個字符
有以下幾種常用特殊格式:
?[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開頭,以一個小寫字母結尾,且中間出現一位任意字符的文件或目錄;
[root@CentOS7 ~]#ls -ld /var/l?[[:lower:]]
[root@CentOS7 ~]#ls -ld /var/l?[a-z]
顯示/etc目錄下,以任意一位數字開頭,且以非數字結尾的文件或目錄;
[root@CentOS7 ~]#ls -ld /etc/[0-9]*[^0-9]
顯示/etc目錄下,以非字母開頭,後面跟一個字母及其它任意長度任意字符的文件或目錄;
[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/[^.]*/
7、復制命令cp:copy
語法格式:cp [OPTION]... 源文件 目標文件
-v:顯示復制過程;
-i:交互式復制,即覆蓋之前提醒用戶確認;
-f:強制覆蓋目標文件;
-r, -R:遞歸復制目錄;
-d:復制符號鏈接文件本身,而非其指向的源文件;
-a:-dR --preserve=all, archive,用於實現歸檔;
--preserv=
mode:權限
ownership:屬主和屬組
timestamps: 時間戳
context:安全標簽
xattr:擴展屬性
links:符號鏈接
all:上述所有屬性
實例:
1、定義別名命令baketc,每天將/etc/目錄下所有文件,備份到/data獨立的子目錄下,並要求子目錄格式為 backupYYYY-mm-dd,備份過程可見
[root@CentOS7 ~]#alias baketc="cp -av /etc/ /data/backup`date +%F`"
2、創建/dat/app/rootdir目錄,並復制/root下所有文件到該目錄內,要求保留原有權限(-p)
[root@CentOS7 ~]#cp -rvp /root/* /data/app/rootdir/
8、移動或重命名mv
語法格式: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
9、刪除文件rm
語法格式:rm [OPTION]... FILE...
i: 交互式
f: 強制
r: 遞歸刪除
實例:刪除目錄/data/app/rootdir下的所有文件
[root@CentOS7 app]#rm -rf /data/app/rootdir/
10、目錄操作命令mkdir、rmdir、tree
創建目錄: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’
文件系統;inode;軟硬連接;文件通配符;文件管理命令:mkdir 、cp、rm、mv、touch