成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

圖解 Linux 文件系統

系統 Linux
眾所周知,內存在斷電后數據就會丟失,所以現代計算機都通過 硬盤 來進行數據存儲。也就是說,硬盤中的數據在斷電后依然能夠保存下來。

[[392353]]

本文轉載自微信公眾號「Linux內核那些事」,作者songsong001 。轉載本文請聯系Linux內核那些事公眾號。

之前我寫過有關 Linux 文件系統源碼分析的文章,但從源碼角度分析文件系統略顯枯燥(對新手不友好),所以這次主要通過圖文的方式來講解 Linux 文件系統的原理,而不用陷入源代碼的深淵之中。

一、硬盤簡介

在介紹文件系統前,我們先來了解一下 硬盤。

眾所周知,內存在斷電后數據就會丟失,所以現代計算機都通過 硬盤 來進行數據存儲。也就是說,硬盤中的數據在斷電后依然能夠保存下來。

現在比較流行的硬盤分為:機械硬盤(HDD) 和 固態硬盤(SSD)。由于本文重點介紹的對象是 文件系統,所以對于硬盤的原理就不進行過多的介紹。下面是 機械硬盤 和 固態硬盤 的對照圖:

 

我們可以把硬盤想象成一個巨大的數組,而數組的每個元素代表一個數據塊,如下圖:

 

在 Linux 內核中,每個數據塊定義為 4KB 的大小,所以一個 128GB 的硬盤可以分為 33554432 個數據塊,內核就是以數據塊的編號來對硬盤進行讀寫操作的。

二、什么是文件系統

前面說過,內核是以數據塊的形式來對硬盤進行讀寫的,但是這對人類來說是非常不直觀的,因為我們不可能記住每一個數據塊保存了什么數據。

為了讓用戶在使用上更方便和直觀,Linux 內核抽象出兩個概念來管理硬盤中的數據:文件(File) 和 目錄(Directory)。

文件:用于保存數據。

目錄:用于保存文件列表,當然目錄也可以保存目錄。

由于數據是保存在硬盤數據塊中,所以文件只需要記錄哪些數據塊屬于當前文件即可。如下圖所示:

 

從上圖可以看出,目錄中既可以保存文件,也可以保存目錄。而文件中保存的是屬于當前文件的數據塊編號,所以當讀寫文件時,只需要找到文件對應的數據塊進行讀寫即可。

三、MINIX 文件系統實現

現在,我們以 MINIX 文件系統來詳細介紹文件系統的設計原理。由于 MINIX 文件系統非常簡單,所以適合用于教學使用。

1. MINIX 文件與目錄

在 MINIX 文件系統中,以 minix2_inode 對象來描述一個文件。我們來看看 minix2_inode 的定義:

  1. struct minix2_inode { 
  2.      __u16 i_mode;     // 模式 
  3.      __u16 i_nlinks;   // 鏈接數 
  4.      __u16 i_uid;      // 所屬用戶UID 
  5.      __u16 i_gid;      // 所屬組ID 
  6.      __u32 i_size;     // 文件大小 
  7.      __u32 i_atime;    // 訪問時間 
  8.      __u32 i_mtime;    // 修改時間 
  9.      __u32 i_ctime;    // 創建時間 
  10.      __u32 i_zone[10]; // 文件數對應的數據塊編號 
  11.  }; 

我們需要特別關注 minix2_inode 對象的 i_zone 字段,它就是用來記錄屬于當前文件的數據塊編號。從定義來看,i_zone 是一個用于 10 個元素的整型數組,那么是否就說明 MINIX 的文件只能保存 40 KB 的數據呢?

答案是否定的,因為 MINIX 文件系統將 i_zone 數組分為 4 個部分:前 7 個元素直接指向保存數據的數據塊編號,也就是數據會直接存儲在這些數據塊上,而第 8 個元素是一級間接指向,第 9 個元素是二級間接指向,第 10 個元素是三級間接指向。我們通過下圖來說明這個關系:

 

通過這種多級指向的方式,一個 MINIX 文件就可以保存超過 40KB 的數據。

有描述文件的對象,那么也應該有描述目錄的對象吧?在 MINIX 文件系統中,目錄也是使用 minix2_inode 對象來描述的。那么怎么區分文件和目錄呢?

在 minix2_inode 對象中有個 名為i_mode 的字段,它保存著 minix2_inode 對應的類型,普通文件使用 S_IFREG 標志來表示,而目錄使用 S_IFDIR 來表示。所以從本質來看,目錄也是一種特殊的文件。

普通文件的數據塊保存的是文件的數據,那么目錄的數據塊保存的是什么?答案就是文件列表,而文件列表的每個表項使用 minix_dir_entry 對象表示,定義如下:

  1. struct minix_dir_entry { 
  2.      __u16 inode; 
  3.      char name[0]; 
  4.  }; 

inode:當前文件對應的 minix2_inode 對象所處于 inode 數組的索引,我們暫時可以忽略此字段的作用,下面將會介紹。

name:用于記錄當前文件的文件名,由于文件名的長度是不固定的,所以這里使用了柔性數組(大小可變的數據)來表示。

我們通過下圖來展示文件與目錄所指向的數據內容的區別:

 

上圖展示了文件與目錄兩個明顯的區別:

  • 文件的 i_mode 字段設置為 S_IFREG,而目錄的 i_mode 字段設置為 S_IFDIR。
  • 文件的 i_zone 字段指向的數據塊保存的是文件的數據,而目錄的 i_zone 字段指向的數據塊保存的是文件列表。

2. MINIX 文件系統格式化

現在,我們基本了解 MINIX 文件系統對文件與目錄的存儲方式了,接下來我們將會介紹 MINIX 文件系統怎么管理硬盤中的文件和目錄,也就是我們常說的 格式化。

前面說過,我們可以把硬盤當成一個由數據塊組成的巨大數組,那么 MINIX 文件系統會把硬盤劃分為以下幾個部分,如下圖所示:

 

下面我們對這幾個部分進行解說:

  • 引導塊:占用一個數據塊,用于操作系統啟動時使用,我們可以忽略。
  • 超級塊:占用一個數據塊,用于保存文件系統的信息,MINIX 文件系統使用 minix_super_block 對象來保存文件系統的信息,如 inode位圖 占用幾個數據塊、數據塊位圖 占用幾個數據塊等。
  • inode位圖:占用若干個數據塊,用于描述 inode表 中哪些成員已經被使用,每個位表示一個 inode 的使用情況。
  • 數據塊位圖:占用若干個數據塊,用于描述 數據塊列表 中哪些成員已經被使用,每個位表示一個數據塊的使用情況。
  • inode表:占用若干個數據塊,由多個 minix2_inode 對象組成,每個 minix2_inode 對象表示一個文件或目錄。
  • 數據塊列表:占用若干個數據塊,用于保存文件的數據。

上圖就是 MINIX 文件系統在硬盤中的格式化結構,我們先來看看 超級塊 記錄的信息有哪些,超級塊是由 minix_super_block 對象表示,其定義如下:

  1. struct minix_super_block { 
  2.      __u16 s_ninodes;       // inode表的元素個數 
  3.      __u16 s_nzones;        // 數據塊列表的元素個數(v1版本) 
  4.      __u16 s_imap_blocks;   // inode位圖占用的數據塊數量 
  5.      __u16 s_zmap_blocks;   // 數據塊位圖占用的數據塊數量 
  6.      __u16 s_firstdatazone; // 第一個數據塊起始號 
  7.      __u16 s_log_zone_size; 
  8.      __u32 s_max_size;      // 文件最大尺寸 
  9.      __u16 s_magic;         // 魔數(用于識別MINIX文件系統) 
  10.      __u16 s_state;         // 文件系統狀態 
  11.      __u32 s_zones;         // 數據塊列表的元素個數(v2版本) 
  12.  }; 

minix_super_block 每個字段的作用都在注釋中進行了說明,通過 minix_super_block 對象我們可以了解到 MINIX 文件系統的信息。

3. 讀取文件過程

了解了 MINIX 文件系統的結構組織,現在我們介紹一下 MINIX 文件系統讀取文件的過程。

例如,我們要讀取 /home/file.txt 文件的內容,MINIX 文件系統是怎么準確地查找到文件并且讀取其中的內容呢?下面我們進行分步來描述這個過程。

第一步:讀取根目錄

要讀取 /home/file.txt 文件,首先要從根目錄 / 開始,MINIX 文件系統約定根目錄使用 inode表 的第一個元素進行存儲。如下圖:

 

如上圖所示,根目錄使用 inode表 的第一個元素進行存儲,然后從根目錄的文件列表中查找目錄 home。從上圖可以看出,home 目錄的 inode索引 為 5,表示 home 目錄存儲在 inode表 的第 5 個元素中。

第二步:讀取 home 目錄

知道 home 目錄的 inode索引 為 5 后,再讀取 inode表 的第 5 個元素,然后再從 home 目錄的文件列表中查找文件 file.txt,過程如下圖:

 

如上圖所示,從 home 目錄的文件列表中找到 file.txt 文件的 inode索引 為 9,所以現在可以通過讀取 inode表 的第 9 個元素來獲得 file.txt 文件對應的 inode 節點。

第三步:讀取 file.txt 文件的內容

現在我們已經知道了 file.txt 文件對應的 inode索引,所以從 inode表 中讀取第 9 個元素即可獲得 file.txt 文件的 inode節點,然后就可以通過 inode節點 的 i_zone 字段所指向的數據塊來讀取文件的內容,如下圖所示:

 

如上圖所示,通過讀取 inode表 的第 9 個元素獲得 file.txt 文件的 inode節點 后,可以通過 inode節點 的 i_zone 字段所指向的數據塊讀取文件的內容。

另外說明一下,inode位圖 和 數據塊位圖 用于創建文件時,快速查找哪些 inode節點 和 數據塊 沒有被使用的。

四、總結

本文通過 MINIX 這種簡單的文件系統來介紹怎么設計一個文件系統,雖然 Linux 系統有多種文件系統,但其基本思想都是怎么有效地管理硬盤的數據。所以,掌握 MINIX 文件系統的設計對理解其他不同的文件系統有非常大的幫助。

責任編輯:武曉燕 來源: Linux內核那些事
相關推薦

2011-01-13 14:10:30

Linux文件系統

2024-02-02 10:38:06

虛擬文件系統VFS

2020-07-22 14:53:06

Linux系統虛擬文件

2021-06-06 16:55:22

Linux文件系統

2009-12-22 15:12:33

Linux擴展文件系統

2009-12-25 09:58:46

linux劃分文件系統

2015-07-10 16:20:26

集群

2021-03-04 13:14:54

文件系統存儲

2021-05-31 07:50:59

Linux文件系統

2009-12-14 13:14:57

2021-11-01 13:38:55

Linux文件系統

2011-01-13 13:18:38

Linux網絡文件

2019-09-20 10:04:45

Linux系統虛擬文件

2018-08-24 10:10:25

Linux文件系統技術

2009-12-18 17:08:10

Linux常見文件系統

2009-09-11 08:41:59

Linux文件系統ACLs權限控制

2019-01-29 10:43:59

Linux 系統 數據

2018-07-02 15:18:39

Linux文件系統

2019-08-27 18:28:54

Linux文件系統文件系統類型

2020-09-25 07:48:12

Linux系統文件
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美成人高清 | 久久91av| 久久国产电影 | 成人一区二区电影 | 精品国产乱码久久久久久蜜退臀 | 2018中文字幕第一页 | 欧美成人综合 | 国产激情在线观看 | 久久一区二区三区电影 | 国产欧美日韩久久久 | 一区| 青青草原综合久久大伊人精品 | 国产乱码精品一区二区三区中文 | 国产精品.xx视频.xxtv | 国产精品久久久久久福利一牛影视 | 午夜欧美| 欧美色人 | 国产98色在线 | 九色在线观看 | 天天操夜夜操 | 日韩精品一区二区三区老鸭窝 | 亚洲 中文 欧美 日韩 在线观看 | 不卡的av电影 | 免费观看日韩精品 | 欧美精三区欧美精三区 | 一区二区视屏 | 四虎永久| 日韩欧美网 | 成人午夜免费视频 | 日韩久久精品视频 | 国产精品久久毛片av大全日韩 | 久久网站免费视频 | 国产欧美日韩 | 欧美精品一区二区三区视频 | 中文字幕国产 | 亚洲国产精品久久久久久 | 看片91| 一级片网站视频 | 久久精品亚洲国产奇米99 | 国产成人精品一区二区三区四区 | 午夜小电影 |