linux下的i節點(node)
對於Unix系列的作業系統,大多都有v節點。但是對於linux來說,只有通用的i節點,卻沒有v節點。
下面來探討一下,linux下的i節點。
linux中,檔案查詢不是通過檔名稱來查詢的。實際上是通過i節點來實現檔案的查詢定位的。我們可以形象的將i節點看做是一個指標fip。當檔案儲存到磁碟上去的時候,檔案肯定會存放到一個磁碟位置上,可以這樣想象,既然檔案資料是存放在磁碟上的,如果我們知道這個檔案資料的地址,當我們想要讀寫檔案的時候,我們是不是直接使用這個地址去找到檔案就可以了呢?
是的,linux下,i節點其實就是可以這麼認為,把i節點看作是一個指向磁碟上該檔案儲存區的地址。只不過這個地址我們一般是沒辦法直接使用的,而是通過檔名來間接使用的。事實上,i節點不僅包含了檔案資料儲存區的地址,還包含了很多資訊,比如資料大小,等等檔案資訊。但是i節點是不儲存檔名的。檔名是儲存在一個目錄項中。每一個目錄項中都包含了檔名和i節點。
我們可以通過一個圖來看看目錄項,i節點,檔案資料四者之間的關係。
從上圖可以看到,目錄項中包含了檔名和i節點。
同時,你會發現上圖中,目錄項A和目錄項B的i節點指向同一個儲存區,其中這個儲存區存放的是printf("ha")的資料。
也就是意味著helloA.c和helloB.c的內容是一樣的。
這就引出了一個硬連結和符號連結的概念
硬連結 ln -d
符號連結 ln -s。
要想得到helloA.c和helloB.c這種關係,我們可以使用如下命令:
#ln -d helloA.c helloB.c
這樣,就得到了helloA.c的硬連結helloB.c
對於硬連結來說。如果刪掉原始檔helloA.c,那麼磁碟上資料檔案時不會刪除的。因為i節點上記錄了該檔案的硬連結數。只有硬連結數是0的時候,刪除檔名的時候,該資料在磁碟上才會刪除。
也就是說。這裡,如果我們使用命令:
# rm -rf helloA.c
helloB.c同樣可以正常使用,其內容就是printf("ha");
但是如果是符號連結:
#ln -s helloB.c helloC.c
這就是所謂的符號連結,符號連結其實是檔案索引的索引。當原始檔helloB.c刪除之後,其實磁碟資料檔案還在,helloC.c也無法使用。
符號連結包含了一個檔名的路徑,如果這個檔名被刪除,這符號連結自然就不能正常工作了。
版權申明: 轉載文章請註明原文出處http://blog.csdn.net/feiyinzilgd/archive/2010/05/19/5609157.aspx 並請聯絡譚海燕本人或者前往譚海燕個人主頁留言