一,Linux的一切皆文件
Linux 中的各種事物比如像文檔、目錄(Mac OS X 和 Windows 系統(tǒng)下稱之為文件夾)、鍵盤、監(jiān)視器、硬盤、可移動媒體設(shè)備、打印機、調(diào)制解調(diào)器、虛擬終端,還有進程間通信(IPC)和網(wǎng)絡(luò)通信等輸入/輸出資源都是定義在文件系統(tǒng)空間下的字節(jié)流。
一切都可看作是文件,其最顯著的好處是對于上面所列出的輸入/輸出資源,只需要相同的一套 Linux 工具、實用程序和 API。你可以使用同一套api(read, write)和工具(cat , 重定向, 管道)來處理unix中大多數(shù)的資源。設(shè)計一個系統(tǒng)的終極目標(biāo)往往就是要找到原子操作,一旦鎖定了原子操作,設(shè)計工作就會變得簡單而有序。“文件”作為一個抽象概念,其原子操作非常簡單,只有讀和寫,這無疑是一個非常好的模型。通過這個模型,API的設(shè)計可以化繁為簡,用戶可以使用通用的方式去訪問任何資源,自有相應(yīng)的中間件做好對底層的適配。
現(xiàn)代操作系統(tǒng)為解決信息能獨立于進程之外被長期存儲引入了文件,文件作為進程創(chuàng)建信息的邏輯單元可被多個進程并發(fā)使用。在 UNIX 系統(tǒng)中,操作系統(tǒng)為磁盤上的文本與圖像、鼠標(biāo)與鍵盤等輸入設(shè)備及網(wǎng)絡(luò)交互等 I/O操作設(shè)計了一組通用 API,使他們被處理時均可統(tǒng)一使用字節(jié)流方式。換言之,UNIX 系統(tǒng)中除進程之外的一切皆是文件,而 Linux 保持了這一特性。為了便于文件的管理,Linux 還引入了目錄(有時亦被稱為文件夾)這一概念。目錄使文件可被分類管理,且目錄的引入使 Linux 的文件系統(tǒng)形成一個層級結(jié)構(gòu)的目錄樹
在Linux系統(tǒng)中,一切都是文件,理解文件系統(tǒng),對于學(xué)習(xí)Linux來說,是一個非常有必要的前提
Linux上的文件系統(tǒng)一般來說就是EXT2或EXT3,但這篇文章并不準(zhǔn)備一上來就直接講它們,而希望結(jié)合Linux操作系統(tǒng)并從文件系統(tǒng)建立的基礎(chǔ)——硬盤開始,一步步認(rèn)識Linux的文件系統(tǒng)。
1. 機械硬盤的物理存儲機制
現(xiàn)代計算機大部分文件存儲功能都是由機械硬盤這種設(shè)備提供的。(現(xiàn)在的SSD和閃存從概念和邏輯上都部分繼承自機械硬盤,所以使用機械硬盤來進行理解也是沒有問題的)機械硬盤能實現(xiàn)信息存儲的功能基于:磁性存儲介質(zhì)能夠被磁化,且磁化后會長久保留被磁化的狀態(tài),這種被磁化狀態(tài)能夠被讀取出來,同時這種磁化狀態(tài)還能夠不斷被修改,磁化正好有兩個方向,所以可以表示0和1。于是硬盤就是把這種磁性存儲介質(zhì)做成一個個盤片,每一個盤片上都分布著數(shù)量巨大的磁性存儲單位,使用磁性讀寫頭對盤片進行寫入和讀取(從原理上類似黑膠唱片的播放)。一個硬盤中的磁性存儲單位數(shù)以億計(1T硬盤就有約80億個),所以需要一套規(guī)則來規(guī)劃信息如何存取(比如一本存儲信息的書我們還會分為頁,每一頁從上到下從左到右讀取,同時還有章節(jié)目錄)于是就有了這些物理、邏輯概念:
1、一個硬盤有多張盤片疊成,不同盤片有編號
2、每張盤片上的存儲顆粒成環(huán)形一圈圈地排布,每一圈稱為磁道,有編號
3、每條磁道上都有一圈存儲顆粒,每512*8(512字節(jié),0.5KB)個存儲顆粒作為一個扇區(qū),扇區(qū)是硬盤上存儲的最小物理單位
4、N個扇區(qū)可以組成簇,N取決于不同的文件系統(tǒng)或是文件系統(tǒng)的配置,簇是此文件系統(tǒng)中的最小存儲單位
5、所有盤面上的同一磁道構(gòu)成一個圓柱,稱為柱面,柱面是系統(tǒng)分區(qū)的最小單位
磁頭讀寫文件的時候,首先是分區(qū)讀寫的,由inode編號(區(qū)內(nèi)唯一的編號后面介紹)找到對應(yīng)的磁道和扇區(qū),然后一個柱面一個柱面地進行讀寫。機械硬盤的讀寫控制系統(tǒng)是一個令人嘆為觀止的精密工程(一個盤面上有幾億個存儲單位,每個磁道寬度不到幾十納米,磁盤每分鐘上萬轉(zhuǎn)),同時關(guān)于讀寫的邏輯也是有諸多細(xì)節(jié)(比如扇區(qū)的編號并不是連續(xù)的),非常有意思,可以自行搜索文章拓展閱讀。 有了硬盤并不意味著LInux可以立刻把它用來存儲,還需要組合進Linux的文件體系才能被Linux使用。
2.Linux文件體系
Linux以文件的形式對計算機中的數(shù)據(jù)和硬件資源進行管理,也就是徹底的一切皆文件,反映在Linux的文件類型上就是:普通文件、目錄文件(也就是文件夾)、設(shè)備文件、鏈接文件、管道文件、套接字文件(數(shù)據(jù)通信的接口)等等。而這些種類繁多的文件被Linux使用目錄樹進行管理, 所謂的目錄樹就是以根目錄(/)為主,向下呈現(xiàn)分支狀的一種文件結(jié)構(gòu)。不同于純粹的ext2之類的文件系統(tǒng),我把它稱為文件體系,一切皆文件和文件目錄樹的資源管理方式一起構(gòu)成了Linux的文件體系,讓Linux操作系統(tǒng)可以方便使用系統(tǒng)資源。所以文件系統(tǒng)比文件體系涵蓋的內(nèi)容少很多,Linux文件體系主要在于把操作系統(tǒng)相關(guān)的東西用文件這個載體實現(xiàn):文件系統(tǒng)掛載在操作系統(tǒng)上,操作系統(tǒng)整個系統(tǒng)又放在文件系統(tǒng)里。但本文中文件體系的相關(guān)內(nèi)容不是很多,大部分地方都可以用文件系統(tǒng)代替文件體系。
1. Linux中的文件類型:
1.1. 普通文件(-)
從Linux的角度來說,類似mp4、pdf、html這樣應(yīng)用層面上的文件類型都屬于普通文件Linux用戶可以根據(jù)訪問權(quán)限對普通文件進行查看、更改和刪除
1.2. 目錄文件(d,directory file)
目錄文件對于用慣Windows的用戶來說不太容易理解,目錄也是文件的一種目錄文件包含了各自目錄下的文件名和指向這些文件的指針,打開目錄事實上就是打開目錄文件,只要有訪問權(quán)限,你就可以隨意訪問這些目錄下的文件(普通文件的執(zhí)行權(quán)限就是目錄文件的訪問權(quán)限),但是只有內(nèi)核的進程能夠修改它們雖然不能修改,但是我們能夠通過vim去查看目錄文件的內(nèi)容
1.3. 符號鏈接(l,symbolic link)
這種類型的文件類似Windows中的快捷方式,是指向另一個文件的間接指針,也就是我們常說的軟鏈接
1.4. 塊設(shè)備文件(b,block)和字符設(shè)備文件(c,char)
這些文件一般隱藏在/dev目錄下,在進行設(shè)備讀取和外設(shè)交互時會被使用到比如磁盤光驅(qū)就是塊設(shè)備文件,串口設(shè)備則屬于字符設(shè)備文件系統(tǒng)中的所有設(shè)備要么是塊設(shè)備文件,要么是字符設(shè)備文件,無一例外
1.5. FIFO(p,pipe)
管道文件主要用于進程間通訊。比如使用mkfifo命令可以創(chuàng)建一個FIFO文件,啟用一個進程A從FIFO文件里讀數(shù)據(jù),啟動進程B往FIFO里寫數(shù)據(jù),先進先出,隨寫隨讀。
1.6. 套接字(s,socket)
用于進程間的網(wǎng)絡(luò)通信,也可以用于本機之間的非網(wǎng)絡(luò)通信這些文件一般隱藏在/var/run目錄下,證明著相關(guān)進程的存在
Linux 的文件是沒有所謂的擴展名的,一個 Linux文件能不能被執(zhí)行與它是否可執(zhí)行的屬性有關(guān),只要你的權(quán)限中有 x ,比如[ -rwx-r-xr-x ] 就代表這個文件可以被執(zhí)行,與文件名沒有關(guān)系。跟在 Windows下能被執(zhí)行的文件擴展名通常是 .com .exe .bat 等不同。不過,可以被執(zhí)行跟可以執(zhí)行成功不一樣。比如在 root 主目錄下的 install.log 是一個文本文件,修改權(quán)限成為 -rwxrwxrwx后這個文件能夠真的執(zhí)行成功嗎? 當(dāng)然不行,因為它的內(nèi)容根本就沒有可以執(zhí)行的數(shù)據(jù)。所以說,這個 x 代表這個文件具有可執(zhí)行的能力, 但是能不能執(zhí)行成功,當(dāng)然就要看該文件的內(nèi)容了。
雖然如此,不過我們?nèi)匀幌M軓臄U展名來了解該文件是什么東西,所以一般我們還是會以適當(dāng)?shù)臄U展名來表示該文件是什么種類的。所以Linux 系統(tǒng)上的文件名真的只是讓你了解該文件可能的用途而已, 真正的執(zhí)行與否仍然需要權(quán)限的規(guī)范才行。比如常見的/bin/ls 這個顯示文件屬性的指令要是權(quán)限被修改為無法執(zhí)行,那么ls 就變成不能執(zhí)行了。這種問題最常發(fā)生在文件傳送的過程中。例如你在網(wǎng)絡(luò)上下載一個可執(zhí)行文件,但是偏偏在你的 Linux 系統(tǒng)中就是無法執(zhí)行,那就可能是檔案的屬性被改變了。而且從網(wǎng)絡(luò)上傳送到你面前 的 Linux 系統(tǒng)中,文件的屬性權(quán)限確實是會被改變的
二,Linux目錄樹
對Linux系統(tǒng)和用戶來說,所有可操作的計算機資源都存在于目錄樹這個邏輯結(jié)構(gòu)中,對計算機資源的訪問都可以認(rèn)為是目錄樹的訪問。就硬盤來說,所有對硬盤的訪問都變成了對目錄樹中某個節(jié)點也就是文件夾的訪問,訪問時不需要知道它是硬盤還是硬盤中的文件夾。目錄樹的邏輯結(jié)構(gòu)也非常簡單,就是從根目錄(/)開始,不斷向下展開各級子目錄。
【文章福利】小編推薦自己的Linux內(nèi)核技術(shù)交流群:【865977150】整理了一些個人覺得比較好的學(xué)習(xí)書籍、視頻資料共享在群文件里面,有需要的可以自行添加哦!!
三,硬盤分區(qū)
硬盤分區(qū)是硬盤結(jié)合到文件體系的第一步,本質(zhì)是「硬盤」這個物理概念轉(zhuǎn)換成「區(qū)」這個邏輯概念,為下一步格式化做準(zhǔn)備。所以分本身并不是必須的,你完全可以把一整塊硬盤作為一個區(qū)。但從數(shù)據(jù)的安全性以及系統(tǒng)性能角度來看,分區(qū)還是有很多用處的,所以一般都會對硬盤進行分區(qū)。
講分區(qū)就不得不先提每塊硬盤上最重要的第一扇區(qū),這個扇區(qū)中有硬盤主引導(dǎo)記錄(Master boot record, MBR) 及分區(qū)表(partition table), 其中 MBR 占有 446 bytes,而分區(qū)表占有 64 bytes。硬盤主引導(dǎo)記錄放有最基本的引導(dǎo)加載程序,是系統(tǒng)開機啟動的關(guān)鍵環(huán)節(jié),在附錄中有更詳細(xì)的說明。而分區(qū)表則跟分區(qū)有關(guān),它記錄了硬盤分區(qū)的相關(guān)信息,但因分區(qū)表僅有 64bytes , 所以最多只能記彔四塊分區(qū)(分區(qū)本身其實就是對分區(qū)表進行設(shè)置)。
只能分四個區(qū)實在太少了,于是就有了擴展分區(qū)的概念,既然第一個扇區(qū)所在的分區(qū)表只能記錄四條數(shù)據(jù), 那我可否利用額外的扇區(qū)來記錄更多的分區(qū)信息。
把普通可以訪問的分區(qū)稱為主分區(qū),擴展分區(qū)不同于主分區(qū),它本身并沒有內(nèi)容,它是為進一步邏輯分區(qū)提供空間的。在某塊分區(qū)指定為擴展分區(qū)后,就可以對這塊擴展分區(qū)進一步分成多個邏輯分區(qū)。操作系統(tǒng)規(guī)定:
1、四塊分區(qū)每塊都可以是主分區(qū)或擴展分區(qū)
2、擴展分區(qū)最多只能有一個(也沒必要有多個)
3、擴展分區(qū)可以進一步分割為多個邏輯分區(qū)
4、擴展分區(qū)只是邏輯概念,本身不能被訪問,也就是不能被格式化后作為數(shù)據(jù)訪問的分區(qū),能夠作為數(shù)據(jù)訪問的分區(qū)只有主分區(qū)和邏輯分區(qū)
5、邏輯分區(qū)的數(shù)量依操作系統(tǒng)而不同,在 Linux 系統(tǒng)中,IDE 硬盤最多有 59 個邏輯分區(qū)(5 號到 63 號), SATA 硬盤則有 11 個邏輯分區(qū)(5 號到 15 號)一般給硬盤進行分區(qū)時,一個主分區(qū)一個擴展分區(qū),然后把擴展分區(qū)劃分為N個邏輯分區(qū)是最好的。
是否可以不要主分區(qū)呢?不知道,但好像不用管,你創(chuàng)建分區(qū)的時候會自動給你配置類型特殊的,你最好單獨分一個swap區(qū)(內(nèi)存置換空間),它獨為一類,功能是:當(dāng)有數(shù)據(jù)被存放在物理內(nèi)存里面,但是這些數(shù)據(jù)又不是常被 CPU 所取用時,那么這些不常被使用的程序?qū)粊G到硬盤的 swap 置換空間當(dāng)中, 而將速度較快的物理內(nèi)存空間釋放出來給真正需要的程序使用
四,格式化
我們知道Linux操作系統(tǒng)支持很多不同的文件系統(tǒng),比如ext2、ext3、XFS、FAT等等,而Linux把對不同文件系統(tǒng)的訪問交給了VFS(虛擬文件系統(tǒng)),VFS能訪問和管理各種不同的文件系統(tǒng)。所以有了區(qū)之后就需要把它格式化成具體的文件系統(tǒng)以便VFS訪問。
標(biāo)準(zhǔn)的Linux文件系統(tǒng)Ext2是使用「基于inode的文件系統(tǒng)」
1、我們知道一般操作系統(tǒng)的文件數(shù)據(jù)除了文件實際內(nèi)容外, 還帶有很多屬性,例如 Linux 操作系統(tǒng)的文件權(quán)限(rwx)與文件屬性(擁有者、群組、 時間參數(shù)等),文件系統(tǒng)通常會將屬性和實際內(nèi)容這兩部分?jǐn)?shù)據(jù)分別存放在不同的區(qū)塊
2、在基于inode的文件系統(tǒng)中,權(quán)限與屬性放置到 inode 中,實際數(shù)據(jù)放到 data block 區(qū)塊中,而且inode和data block都有編號
Ext2 文件系統(tǒng)在此基礎(chǔ)上:
1、文件系統(tǒng)最前面有一個啟動扇區(qū)(boot sector)
- 這個啟動扇區(qū)可以安裝開機管理程序, 這個設(shè)計讓我們能將不同的引導(dǎo)裝載程序安裝到個別的文件系統(tǒng)前端,而不用覆蓋整個硬盤唯一的MBR, 也就是這樣才能實現(xiàn)多重引導(dǎo)的功能
2、把每個區(qū)進一步分為多個塊組 (block group),每個塊組有獨立的inode/block體系
- 如果文件系統(tǒng)高達(dá)數(shù)百 GB 時,把所有的 inode 和block 通通放在一起會因為 inode 和 block的數(shù)量太龐大,不容易管理
- 這其實很好理解,因為分區(qū)是用戶的分區(qū),實際計算機管理時還有個最適合的大小,于是計算機會進一步的在分區(qū)中分塊
- (但這樣豈不是可能出現(xiàn)大文件放不了的問題?有什么機制善后嗎?)
3、每個塊組實際還會分為分為6個部分,除了inode table 和 data block外還有4個附屬模塊,起到優(yōu)化和完善系統(tǒng)性能的作用
所以整個分區(qū)大概會這樣劃分:
inode table
1.主要記錄文件的屬性以及該文件實際數(shù)據(jù)是放置在哪些block中,它記錄的信息至少有這些:
- 大小、真正內(nèi)容的block號碼(一個或多個)
- 訪問模式(read/write/excute)
- 擁有者與群組(owner/group)
- 各種時間:建立或狀態(tài)改變的時間、最近一次的讀取時間、最近修改的時間
- 沒有文件名!文件名在目錄的block中!
2、一個文件占用一個 inode,每個inode有編號
3、Linux 系統(tǒng)存在 inode 號被用完但磁盤空間還有剩余的情況
4、注意,這里的文件不單單是普通文件,目錄文件也就是文件夾其實也是一個文件,還有其他的也是
5、inode 的數(shù)量與大小在格式化時就已經(jīng)固定了,每個inode 大小均固定為128 bytes (新的ext4 與xfs 可設(shè)定到256 bytes)
6、文件系統(tǒng)能夠建立的文件數(shù)量與inode 的數(shù)量有關(guān),存在空間還夠但inode不夠的情況
7、系統(tǒng)讀取文件時需要先找到inode,并分析inode 所記錄的權(quán)限與使用者是否符合,若符合才能夠開始實際讀取 block 的內(nèi)容
8、inode 要記錄的資料非常多,但偏偏又只有128bytes , 而inode 記錄一個block 號碼要花掉4byte ,假設(shè)我一個文件有400MB 且每個block 為4K 時, 那么至少也要十萬條block 號碼的記錄!inode 哪有這么多空間來存儲?為此我們的系統(tǒng)很聰明的將inode 記錄block 號碼的區(qū)域定義為12個直接,一個間接, 一個雙間接與一個三間接記錄區(qū)(詳細(xì)見附錄)
data block
1、放置文件內(nèi)容數(shù)據(jù)的地方
2、在格式化時block的大小就固定了,且每個block都有編號,以方便inode的記錄
- 原則上,block 的大小與數(shù)量在格式化完就不能夠再改變了(除非重新格式化)
3、在Ext2文件系統(tǒng)中所支持的block大小有1K, 2K及4K三種,由于block大小的區(qū)別,會導(dǎo)致該文件系統(tǒng)能夠支持的最大磁盤容量與最大單一文件容量各不相同:
- Block 大小 1KB 2KB 4KB
- 最大單一檔案限制 16GB 256GB 2TB
- 最大檔案系統(tǒng)總?cè)萘?2TB 8TB 16TB
4、每個block 內(nèi)最多只能夠放置一個文件的資料,但一個文件可以放在多個block中(大的話)
5、若文件小于block ,則該block 的剩余容量就不能夠再被使用了(磁盤空間會浪費)
- 所以如果你的檔案都非常小,但是你的block 在格式化時卻選用最大的4K 時,可能會產(chǎn)生容量的浪費
- 既然大的block 可能會產(chǎn)生較嚴(yán)重的磁碟容量浪費,那么我們是否就將block 大小定為1K ?這也不妥,因為如果block 較小的話,那么大型檔案將會占用數(shù)量更多的block ,而inode 也要記錄更多的block 號碼,此時將可能導(dǎo)致檔案系統(tǒng)不良的讀寫效能
- 事實上現(xiàn)在的磁盤容量都太大了,所以一般都會選擇4K 的block 大小
superblock
1、記錄整個文件系統(tǒng)相關(guān)信息的地方,一般大小為1024bytes,記錄的信息主要有:
- block 與inode 的總量
- 未使用與已使用的inode / block 數(shù)量
- 一個valid bit 數(shù)值,若此文件系統(tǒng)已被掛載,則valid bit 為0 ,若未被掛載,則valid bit 為1
- block 與inode 的大小 (block 為1, 2, 4K,inode 為128bytes 或256bytes);
- 其他各種文件系統(tǒng)相關(guān)信息:filesystem 的掛載時間、最近一次寫入資料的時間、最近一次檢驗磁碟(fsck) 的時間
2、Superblock是非常重要的, 沒有Superblock ,就沒有這個文件系統(tǒng)了,因此如果superblock死掉了,你的文件系統(tǒng)可能就需要花費很多時間去挽救
3、每個塊都可能含有superblock,但是我們也說一個文件系統(tǒng)應(yīng)該僅有一個superblock 而已,那是怎么回事?事實上除了第一個塊內(nèi)會含有superblock 之外,后續(xù)的塊不一定含有superblock,而若含有superblock則該superblock主要是做為第一個塊內(nèi)superblock的備份,這樣可以進行superblock的救援
Filesystem Description
1、文件系統(tǒng)描述
2、這個區(qū)段可以描述每個block group的開始與結(jié)束的block號碼,以及說明每個區(qū)段(superblock, bitmap, inodemap, data block)分別介于哪一個block號碼之間
block bitmap
1、塊對照表
2、如果你想要新增文件時要使用哪個block 來記錄呢?當(dāng)然是選擇「空的block」來記錄。那你怎么知道哪個block 是空的?這就得要通過block bitmap了,它會記錄哪些block是空的,因此我們的系統(tǒng)就能夠很快速的找到可使用的空間來記錄
3、同樣在你刪除某些文件時,那些文件原本占用的block號碼就得要釋放出來, 此時在block bitmap 中對應(yīng)該block號碼的標(biāo)志位就得要修改成為「未使用中」
inode bitmap
1、與block bitmap 是類似的功能,只是block bitmap 記錄的是使用與未使用的block 號碼, 至于inode bitmap 則是記錄使用與未使用的inode 號碼
五,掛載
在一個區(qū)被格式化為一個文件系統(tǒng)之后,它就可以被Linux操作系統(tǒng)使用了,只是這個時候Linux操作系統(tǒng)還找不到它,所以我們還需要把這個文件系統(tǒng)「注冊」進Linux操作系統(tǒng)的文件體系里,這個操作就叫「掛載」 (mount)。掛載是利用一個目錄當(dāng)成進入點(類似選一個現(xiàn)成的目錄作為代理),將文件系統(tǒng)放置在該目錄下,也就是說,進入該目錄就可以讀取該文件系統(tǒng)的內(nèi)容,類似整個文件系統(tǒng)只是目錄樹的一個文件夾(目錄)。這個進入點的目錄我們稱為「掛載點」。
由于整個 Linux 系統(tǒng)最重要的是根目錄,因此根目錄一定需要掛載到某個分區(qū)。 而其他的目錄則可依用戶自己的需求來給予掛載到不同的分去。
到這里L(fēng)inux的文件體系的構(gòu)建過程其實已經(jīng)大體講完了,總結(jié)一下就是:硬盤經(jīng)過分區(qū)和格式化,每個區(qū)都成為了一個文件系統(tǒng),掛載這個文件系統(tǒng)后就可以讓Linux操作系統(tǒng)通過VFS訪問硬盤時跟訪問一個普通文件夾一樣。這里通過一個在目錄樹中讀取文件的實際例子來細(xì)講一下目錄文件和普通文件。
6.目錄樹的讀取過程
首先我們要知道:
1、每個文件(不管是一般文件還是目錄文件)都會占用一個inode
2、依據(jù)文件內(nèi)容的大小來分配一個或多個block給該文件使用
3、創(chuàng)建一個文件后,文件完整信息分布在3處地方,生成2個新文件:
- 文件名記錄在該文件所在目錄的目錄文件的block中,沒有新文件生成
- 文件屬性、權(quán)限信息、記錄具體內(nèi)容的block編號記錄在inode中,inode是新生成文件
- 文件具體內(nèi)存記錄在block中,block是新生成文件
4、因為文件名的記錄是在目錄的block當(dāng)中,「新增/刪除/更名文件名」與目錄的w權(quán)限有關(guān)所以在Linux/Unix中,文件名稱只是文件的一個屬性,叫別名也好,叫綽號也罷,僅為了方便用戶記憶和使用,但系統(tǒng)內(nèi)部并不需要用文件名來定為文件位置,這樣處理最直觀的好處就是,你可以對正在使用的文件改名,換目錄,甚至放到廢紙簍,都不會影響當(dāng)前文件的使用,這在Windows里是無法想象的。比如你打開個Word文件,然后對其進行重命名操作,Windows會告訴你門兒都沒有,關(guān)閉文件先!但在Mac里就毫無壓力,因為Mac的操作系統(tǒng)同樣采用了inode的設(shè)計。
創(chuàng)建文件過程
當(dāng)在ext2下建立一個一般文件時, ext2 會分配一個inode 與相對于該文件大小的block 數(shù)量給該文件
- 例如:假設(shè)我的一個block 為4 Kbytes ,而我要建立一個100 KBytes 的文件,那么linux 將分配一個inode 與25 個block 來儲存該文件
- 但同時請注意,由于inode 僅有12 個直接指向,因此還要多一個block 來作為區(qū)塊號碼的記錄
創(chuàng)建目錄過程
當(dāng)在ext2文件系統(tǒng)建立一個目錄時(就是新建了一個目錄文件),文件系統(tǒng)會分配一個inode與至少一塊block給該目錄
- inode記錄該目錄的相關(guān)權(quán)限與屬性,并記錄分配到的那塊block號碼
- 而block則是記錄在這個目錄下的文件名與該文件對應(yīng)的inode號
- block中還會自動生成兩條記錄,一條是.文件夾記錄,inode指向自身,另一條是..文件夾記錄,inode指向父文件夾
從目錄樹中讀取某個文件過程
- 因為文件名是記錄在目錄的block當(dāng)中,因此當(dāng)我們要讀取某個文件時,就一定會經(jīng)過目錄的inode與block ,然后才能夠找到那個待讀取文件的inode號碼,最終才會讀到正確的文件的block內(nèi)的資料。
- 由于目錄樹是由根目錄開始,因此操作系統(tǒng)先通過掛載信息找到掛載點的inode號,由此得到根目錄的inode內(nèi)容,并依據(jù)該inode讀取根目錄的block信息,再一層一層的往下讀到正確的文件。舉例來說,如果我想要讀取/etc/passwd 這個文件時,系統(tǒng)是如何讀取的呢?先看一下這個文件以及有關(guān)路徑文件夾的信息:
1$ ll -di / /etc /etc/passwd
2 128 dr-xr-x r-x . 17 root root 4096 May 4 17:56 /
333595521 drwxr-x r-x . 131 root root 8192 Jun 17 00:20 /et
c436628004 -rw-r-- r-- . 1 root root 2092 Jun 17 00:20 /etc/passwd
于是該文件的讀取流程為:
1、/的inode:
通過掛載點的信息找到inode號碼為128的根目錄inode,且inode規(guī)定的權(quán)限讓我們可以讀取該block的內(nèi)容(有r與x)
2、/的block:
經(jīng)過上個步驟取得block的號碼,并找到該內(nèi)容有etc/目錄的inode號碼(33595521)
3、etc/的inode:
讀取33595521號inode得知具有r與x的權(quán)限,因此可以讀取etc/的block內(nèi)容
4、etc/的block:
經(jīng)過上個步驟取得block號碼,并找到該內(nèi)容有passwd文件的inode號碼(36628004)
5、passwd的inode:
讀取36628004號inode得知具有r的權(quán)限,因此可以讀取passwd的block內(nèi)容
6、passwd的block:
最后將該block內(nèi)容的資料讀出來
評論
查看更多