Linux一個重要的哲學是:一切皆文件。而文件與文件系統是密切相關的,本篇筆記我們來一起學習、理清那些令我們眼花繚亂的文件系統。
文件系統粗略的分類:
下面依次進行介紹:
根文件系統
根文件系統(rootfs)是內核啟動時所 mount(掛載)的第一個文件系統,內核代碼映像文件保存在根文件系中,而系統引導啟動程序會在根文件系統掛載之后從中把一些基本的初始化腳本和服務等加載到內存中去運行。
根文件系統的根目錄/下有很多子目錄:
虛擬文件系統
從上面的分類圖中我們可以知道Linux中有很多文件系統,并且是共存的。那么在Linux中是怎么做到讓一切都是文件呢?這是由于有一層虛擬文件系統軟件抽象層的存在,這個軟件抽象層為用戶屏蔽了底層文件系統的差異,向上層提供了統一地訪問接口。如圖:
(圖片來源:野火電子)
無論最下層的文件系統是什么,我們最上層的用戶端盡管使用系統調用接口(open、write、read等)或glibc接口(fopen、fwrite、fread等)來操作就可訪問文件系統里的文件,使得一切都是文件成為可能。
真文件系統
真文件系統其實是實際存儲設備的文件系統,掛載于EEPROM、 Nor FLASH、 NAND FLASH、 eMMC 等存儲器中。
1、ext2
EXT2第二代擴展文件系統(second extended filesystem,縮寫為 ext2),是Linux內核早期所用的文件系統,但是隨著技術的發展 ext2 文件系統已經不推薦使用了。ext2是一個非日志文件系統。
2、ext3
EXT3是第三代擴展文件系統(Third extended filesystem,縮寫為ext3),是一個日志文件系統。主要特點:
高可用性:系統使用了ext3文件系統后,即使在非正常關機后,系統也不需要檢查文件系統。宕機發生后,恢復ext3文件系統的時間只要數十秒鐘。
數據完整性:ext3文件系統能夠極大地提高文件系統的完整性,避免了意外宕機對文件系統的破壞。
3、ext4
EXT4是第四代擴展文件系統(Fourth extended filesystem,縮寫為 ext4)是一個日志文件系統,是ext3文件系統的后繼版本。主要特點:
更多的子目錄數量:Ext3目前只支持32000個子目錄,而Ext4取消了這一限制,理論上支持無限數量的子目錄。
更多的塊和i-節點數量:Ext3文件系統使用32位空間記錄塊數量和i-節點數量,而Ext4文件系統將它們擴充到64位。
偽文件系統
Linux內核提供了sysfs、procfs、devtmpfs等偽文件系統,偽文件系統存在于內存,不占用硬盤。以文件地形式向用戶提供一些系統信息,用戶讀寫這些文件就可以讀取、修改系統的一些信息。
1、procfs
procfs是 進程文件系統的縮寫,包含一個偽文件系統(啟動時動態生成的文件系統),用于通過內核訪問進程信息。這個文件系統通常被掛載到 /proc 目錄。
由于 /proc 不是一個真正的文件系統,它也就不占用存儲空間,只是占用有限的內存。
/proc目錄的內容如下:
其中,這些以數字命名的文件夾就是與進程相關的部分,這些數字就是進程的PID號。
我們可以訪問系統信息,如讀取CPU相關信息:
查看內核支持的文件系統類型:
可見,內核支持了很多文件系統,我們上面的文件系統匯總只列出了一小部分,感興趣的朋友可以自己去了解其它的。
我們可以通過/proc目錄了解到很多信息,大家可以自行嘗試查看其它信息。
2、sysfs
sysfs是一個基于內存的文件系統,它的作用是將內核信息以文件的方式提供給用戶程序使用。sysfs 文件系統被掛載在 /sys 掛載點上。/sys目錄下的內容如:
上一篇分享了《看看你的嵌入式設備CPU溫度是多少,能烤肉嗎?》中,我們讀取/sys/devices/virtual/thermal/thermal_zone0下的temp文件就可以得到cpu的溫度。
sysfs 與 proc 相比有很多優點,最重要的莫過于設計上的清晰。sysfs 的設計原則是一個屬性文件只做一件事情, sysfs 屬性文件一般只有一個值,直接讀取或寫入。
整個 /proc/scsi目錄在2.6內核中已被標記為過時(LEGACY),它的功能已經被相應的 /sys 屬性文件所完全取代。新設計的內核機制應該盡量使用 sysfs 機制,而將 proc 保留給純凈的“進程文件系統”。
3、devtmpfs
devtmpfs 的功用是在 Linux 核心 啟動早期建立一個初步的 /dev,令一般啟動程序不用等待 udev(udev 是Linux kernel 2.6系列的設備管理器。它主要的功能是管理/dev目錄底下的設備節點。),縮短 GNU/Linux 的開機時間。
在devtmpfs出現之前,/dev/下面的設備節點應該都是udev-daemon收到內核的事件后用mknod程序或者直接調mknod()系統調用創建出來的;現在基本上不走udev了,幾乎所有的設備文件(比如/dev/sda1)都是內核直接創建的。
我們在之前hello驅動、led驅動實驗中,我們動態加載的方式加載我們的驅動程序之后,會在/dev目錄下生成相應的節點。我們只要在應用程序中操作這個節點就可以間接地操控我們的led:
再一次體現了Linux中一切皆文件的概念。
相關筆記推薦:
《嵌入式Linux驅動基礎》
《LED驅動實驗(總線設備驅動模型)》
網絡文件系統
NFS(Network File System) ,即網絡文件系統, 能使使用者訪問網絡上別處的文件就像在使用自己的計算機一樣。其工作原理是使用客戶端/服務器架構 :
服務器程序向其他計算機提供對文件系統的訪問,其過程稱為輸出。NFS客戶端程序對共享文件系統進行訪問時,把它們從NFS服務器中“輸送”出來。
文件通常以塊為單位進行傳輸。在我們嵌入式Linux中,NFS的主要應用如:把主機的上文件(比如目標板的可執行文件)共享給目標板,這樣目標板就很方便地運行程序。比如我們往期筆記【Linux筆記】掛載網絡文件系統中的實驗框圖:
以上就是本次的筆記分享,如有錯誤,歡迎指出,謝謝!本次著重分享了幾個重要的文件系統,了解這幾個文件系統對我們學習嵌入式Linux有幫助。
責任編輯:xj
原文標題:Linux中文件系統分類,以及基礎使用方法
文章出處:【微信公眾號:strongerHuang】歡迎添加關注!文章轉載請注明出處。
-
Linux
+關注
關注
87文章
11292瀏覽量
209332 -
文件系統
+關注
關注
0文章
284瀏覽量
19904
原文標題:Linux中文件系統分類,以及基礎使用方法
文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論