Linux 軟鏈結和硬鏈結簡介

2021-09-25 21:54:14 字數 2530 閱讀 3171

在linux系統中,將檔案分為兩個部分:使用者資料和元資料。

元資料(inode)

元資料即檔案的索引節點(inode),用來記錄檔案的許可權(r、w、x)、檔案的所有者和屬組、檔案的大小、檔案的狀態改變時間(ctime)、檔案的最近一次讀取時間(atime)、檔案的最近一次修改時間(mtime)、檔案資料的block編號。

inode的預設大小為128byte,新的ext4和xfs可以設定為256byte。

在linux中,元資料中的inode號,即索引節點號,才是檔案的唯一標識而非檔名。檔名僅是為了方便人們的記憶和使用,系統或程式通過inode號尋找正確的檔案資料塊。

使用者資料(block)

使用者資料即檔案資料塊(block),記錄了檔案的真實內容,包括檔名,檔名會被記錄在上級目錄的block中。也就是說,目錄的block中記錄的是這個目錄下所有一級子檔案和子目錄的檔名及inode的對應,而檔案的block中記錄的才是檔案實際的資料。

block的大小可以是1kb、2kb、4kb,預設為4kb。block用於實際的資料儲存,如果乙個block放不下資料,則可以占用多個block,最後乙個block可能不會佔滿,但也不能再放入其他檔案的資料。多個block有可能是連續的,也有可能是分散的。

硬鏈結(hard link)

含義

硬鏈結共用同乙個inode號,只是檔名不同。

查詢檔案的步驟

1)首先找到根目錄的inode(根目錄的inode是系統已知的,inode號是2),然後判斷使用者是否有許可權訪問根目錄的block。

2)如果有許可權,則可以在根目錄的block中訪問到/root的檔名及對應的inode號。

3)通過/root/目錄的inode號,可以查詢到/root/目錄的inode資訊,接著判斷使用者是否有許可權訪問/root/目錄的block。

4)如果有許可權,則可以從/root/目錄的block中讀取到test-hard檔案的檔名及對應的inode號。

5)通過test-hard檔案的inode號,就可以找到test-hard檔案的inode資訊,接著判斷使用者是否有許可權訪問test-hard檔案的block。

6)如果有許可權,則可以讀取block中的資料,這樣就完成了/root/test-hard檔案的讀取與訪問。

硬鏈結的特點

1)不論是修改原始檔(test檔案),還是修改硬鏈結檔案(test-hard檔案),另乙個檔案中的資料都會發生改變。

2)不論是刪除原始檔,還是刪除硬鏈結檔案,只要還有乙個檔案存在,這個檔案都可以被訪問。

3)硬鏈結不會建立新的inode資訊,也不會更改inode的總數。

4)硬鏈結不能跨檔案系統(分割槽)建立,因為在不同的檔案系統中,inode號是重新計算的。

5)硬鏈結不能鏈結目錄,因為如果給目錄建立硬鏈結,那麼不僅目錄本身需要重新建立,目錄下所有的子檔案,包括子目錄中的所有子檔案都需要建立硬鏈結,這對當前的linux來講過於複雜。

6)硬鏈結不會占用inode和block。

軟鏈結(symbolic link)

含義

軟鏈結有著自己的inode號以及使用者資料塊。只不過使用者資料塊中存放的內容是另一檔案的路徑名的指向。

查詢檔案的步驟

1)首先找到根目錄的inode索引資訊,然後判斷使用者是否有許可權訪問根目錄的block。

2)如果有許可權訪問根目錄的block,就會在block中查詢到/root/目錄的inode號。

3)接著訪問/root/目錄的inode資訊,判斷使用者是否有許可權訪問/root/目錄的block。

4)如果有許可權,就會在block中讀取到軟鏈結檔案test-soft的inode號。因為軟鏈結檔案會真正建立自己的inode索引和block,所以軟鏈結檔案和原始檔的inode號是不一樣的。

5)通過軟鏈結檔案的inode號,找到了test-soft檔案inode資訊,判斷使用者是否有許可權訪問block。

6)如果有許可權,就會發現test-soft檔案的block中沒有實際資料,僅有原始檔test的inode號。

7)接著通過原始檔的inode號,訪問到原始檔test的inode資訊,判斷使用者是否有許可權訪問block。

8)如果有許可權,就會在test檔案的block中讀取到真正的資料,從而完成資料訪問。

軟連線的特點

1)不論是修改原始檔(test),還是修改硬鏈結檔案(test-soft),另乙個檔案中的資料都會發生改變。

2)刪除軟鏈結檔案,原始檔不受影響。而刪除原檔案,軟鏈結檔案將找不到實際的資料,從而顯示檔案不存在。

3)軟鏈結會新建自己的inode資訊和block,只是在block中不儲存實際檔案資料,而儲存的是原始檔的檔名及inode號。

4)軟鏈結可以鏈結目錄。

5)軟鏈結可以跨分割槽。

6)軟鏈結會占用inode和block。

Linux 硬鏈結和軟鏈結

硬鏈結是通過鏈結原始檔的索引節點來進行有效鏈結。linux系統中的每個檔案都有乙個自己的索引節點,如同資料庫中的每條記錄都有自己的唯一索引一樣。自我感覺硬鏈結就像是windows下乙個檔案的拷貝,唯一不同的地方是多個該檔案的拷貝 硬鏈結 通過原始檔的索引節點來共享和更新自己的內容,一旦該節點上的任一...

Linux軟鏈結和硬鏈結

1.linux鏈結概念 linux鏈結分兩種,一種被稱為硬鏈結 hard link 另一種被稱為符號鏈結 symbolic link 預設情況下,ln命令產生硬鏈結。硬連線 硬連線指通過索引節點來進行連線。在linux的檔案系統中,儲存在磁碟分割槽中的檔案不管是什麼型別都給它分配乙個編號,稱為索引節...

Linux軟鏈結和硬鏈結

1.linux鏈結概念 linux鏈結分兩種,一種被稱為硬鏈結 hard link 另一種被稱為符號鏈結 symbolic link 預設情況下,ln命令產生硬鏈結。硬鏈結 硬鏈結指通過索引節點來進行鏈結。在linux的檔案系統中,儲存在磁碟分割槽中的檔案不管是什麼型別都給它分配乙個編號,稱為索引節...