精品免费在线观看-精品欧美-精品欧美成人bd高清在线观看-精品欧美高清不卡在线-精品欧美日韩一区二区

17站長(zhǎng)網(wǎng)

Linux中的EXT系列文件系統(tǒng)格式詳解

2022-10-6 15:10| 查看: 1420 |來源: 互聯(lián)網(wǎng)

Linux文件系統(tǒng) 常見的硬盤如上圖所示,每個(gè)盤片分多個(gè)磁道,每個(gè)磁道分多個(gè)扇區(qū),每個(gè)扇區(qū)512字節(jié),是硬盤的最小存儲(chǔ)單元,但是在操作系統(tǒng)層面會(huì)將多個(gè)扇區(qū) ...

Linux文件系統(tǒng)

常見的硬盤如上圖所示,每個(gè)盤片分多個(gè)磁道,每個(gè)磁道分多個(gè)扇區(qū),每個(gè)扇區(qū)512字節(jié),是硬盤的最小存儲(chǔ)單元,但是在操作系統(tǒng)層面會(huì)將多個(gè)扇區(qū)組成塊(block),是操作系統(tǒng)存儲(chǔ)數(shù)據(jù)的最小單元,通常是8個(gè)扇區(qū)組成4K字節(jié)的塊。
對(duì)于Linux文件系統(tǒng),需要考慮以下幾點(diǎn):

  • 文件系統(tǒng)需要有嚴(yán)格的組織形式,使文件能夠以塊為單位存儲(chǔ)

  • 文件系統(tǒng)需要有索引區(qū),方便查找一個(gè)文件分成的多個(gè)塊存在了什么位置

  • 如果有文件近期經(jīng)常被讀寫,需要有緩存層

  • 文件應(yīng)該用文件夾的形式組織起來方便管理和查詢

  • Linux內(nèi)核要在自己的內(nèi)存里維護(hù)一套數(shù)據(jù)結(jié)構(gòu),保持哪些文件被哪些進(jìn)程打開和使用

Linux里面一切皆文件,都有以下幾種文件(從ls -l結(jié)果的第一位標(biāo)識(shí)位可以看出來):

  • - 表示普通文件

  • d 表示文件夾

  • c 表示字符設(shè)備文件

  • b 表示塊設(shè)備文件

  • s 表示套接字socket文件

  • l 表示軟鏈接

Inode和塊存儲(chǔ)

下面就以EXT系列格式為例來看一下文件是如果存在硬盤上的。首先文件會(huì)被分成一個(gè)個(gè)的塊,分散得存在硬盤上,就需要一個(gè)索引結(jié)構(gòu)來幫助我們找到這些塊以及記錄文件的一些元信息,這就是inode,其中i代表index。inode數(shù)據(jù)結(jié)構(gòu)如下:

  1. struct ext4_inode {
  2.  __le16 i_mode;  /* File mode */
  3.  __le16 i_uid;  /* Low 16 bits of Owner Uid */
  4.  __le32 i_size_lo; /* Size in bytes */
  5.  __le32 i_atime; /* Access time */
  6.  __le32 i_ctime; /* Inode Change time */
  7.  __le32 i_mtime; /* Modification time */
  8.  __le32 i_dtime; /* Deletion Time */
  9.  __le16 i_gid;  /* Low 16 bits of Group Id */
  10.  __le16 i_links_count; /* Links count */
  11.  __le32 i_blocks_lo; /* Blocks count */
  12.  __le32 i_flags; /* File flags */
  13.  union {
  14.   struct {
  15.    __le32 l_i_version;
  16.   } linux1;
  17.   struct {
  18.    __u32 h_i_translator;
  19.   } hurd1;
  20.   struct {
  21.    __u32 m_i_reserved1;
  22.   } masix1;
  23.  } osd1;    /* OS dependent 1 */
  24.  __le32 i_block[EXT4_N_BLOCKS];/* Pointers to blocks */
  25.  __le32 i_generation; /* File version (for NFS) */
  26.  __le32 i_file_acl_lo; /* File ACL */
  27.  __le32 i_size_high;
  28.  __le32 i_obso_faddr; /* Obsoleted fragment address */
  29.  union {
  30.   struct {
  31.    __le16 l_i_blocks_high; /* were l_i_reserved1 */
  32.    __le16 l_i_file_acl_high;
  33.    __le16 l_i_uid_high; /* these 2 fields */
  34.    __le16 l_i_gid_high; /* were reserved2[0] */
  35.    __le16 l_i_checksum_lo;/* crc32c(uuid+inum+inode) LE */
  36.    __le16 l_i_reserved;
  37.   } linux2;
  38.   struct {
  39.    __le16 h_i_reserved1; /* Obsoleted fragment number/size which are removed in ext4 */
  40.    __u16 h_i_mode_high;
  41.    __u16 h_i_uid_high;
  42.    __u16 h_i_gid_high;
  43.    __u32 h_i_author;
  44.   } hurd2;
  45.   struct {
  46.    __le16 h_i_reserved1; /* Obsoleted fragment number/size which are removed in ext4 */
  47.    __le16 m_i_file_acl_high;
  48.    __u32 m_i_reserved2[2];
  49.   } masix2;
  50.  } osd2;    /* OS dependent 2 */
  51.  __le16 i_extra_isize;
  52.  __le16 i_checksum_hi; /* crc32c(uuid+inum+inode) BE */
  53.  __le32 i_ctime_extra; /* extra Change time (nsec << 2 | epoch) */
  54.  __le32 i_mtime_extra; /* extra Modification time(nsec << 2 | epoch) */
  55.  __le32 i_atime_extra; /* extra Access time (nsec << 2 | epoch) */
  56.  __le32 i_crtime; /* File Creation time */
  57.  __le32 i_crtime_extra; /* extra FileCreationtime (nsec << 2 | epoch) */
  58.  __le32 i_version_hi; /* high 32 bits for 64-bit version */
  59.  __le32 i_projid; /* Project ID */
  60. };

其中__le32 i_block[EXT4_N_BLOCKS]存儲(chǔ)了到數(shù)據(jù)塊的引用,EXT4_N_BLOCKS定義如下:

  1. #define EXT4_NDIR_BLOCKS 12
  2. #define EXT4_IND_BLOCK EXT4_NDIR_BLOCKS
  3. #define EXT4_DIND_BLOCK (EXT4_IND_BLOCK + 1)
  4. #define EXT4_TIND_BLOCK (EXT4_DIND_BLOCK + 1)
  5. #define EXT4_N_BLOCKS (EXT4_TIND_BLOCK + 1)

在ext2和ext3中i_block前12項(xiàng)存儲(chǔ)了直接到數(shù)據(jù)塊的引用,第13項(xiàng)存儲(chǔ)的是到間接塊的引用,在間接塊里存儲(chǔ)著數(shù)據(jù)塊的位置,以此類推,第14項(xiàng)里存儲(chǔ)著二次間接快的位置,第15項(xiàng)里存儲(chǔ)著三次間接塊的位置,如下圖所示:

不難看出,對(duì)于大文件,需要多次讀取硬盤才能找到相應(yīng)的塊,在ext4中就提出了Extents Tree來解決這一問題,其核心思想就是把連續(xù)的塊用開始位置加塊的個(gè)數(shù)來表示,不再是一個(gè)一個(gè)去記錄每一個(gè)塊的位置,這樣就能節(jié)約存儲(chǔ)空間。首先,它將i_block中原來415=60字節(jié)的空間換成了一個(gè)extent header(ext4_extent_header)加4個(gè)extent entry(ext4_extent),因?yàn)閑xt4_extent_header和ext4_extent都是占用了12字節(jié)。ee_len中的第一個(gè)bit用來判斷是否初始化,所以它還能存儲(chǔ)最大32K個(gè)數(shù),所以一個(gè)extent entry里最大可以存32K4K=128M的數(shù)據(jù),如果一個(gè)文件大于4128M=512M或者這個(gè)文件被分散到多于4個(gè)不連續(xù)的塊中存儲(chǔ),我們就需要擴(kuò)展inode中的i_block結(jié)構(gòu)。它的extent entry就要從ext4_extent被換成ext4_extent_idx結(jié)構(gòu)體,它所指向的是一個(gè)塊,有4K字節(jié),除去header占用的12字節(jié),還能存340個(gè)ext4_extent,最大可以存340128M=42.5G的數(shù)據(jù)。可以看出這種索引結(jié)構(gòu)在文件用連續(xù)的塊存儲(chǔ)時(shí)非常高效。

  1. struct ext4_extent_header {
  2.  __le16 eh_magic; /* ext4 extents標(biāo)識(shí):0xF30A */
  3.  __le16 eh_entries; /* 當(dāng)前層級(jí)中有效節(jié)點(diǎn)的數(shù)目 */
  4.  __le16 eh_max; /* 當(dāng)前層級(jí)中最大節(jié)點(diǎn)的數(shù)目 */
  5.  __le16 eh_depth; /* 當(dāng)前層級(jí)在樹中的深度,0為葉子節(jié)點(diǎn),即數(shù)據(jù)節(jié)點(diǎn),>0代表索引節(jié)點(diǎn) */
  6.  __le32 eh_generation; 
  7. }
  8. struct ext4_extent {
  9.  __le32 ee_block; /* extent的起始block邏輯序號(hào) */
  10.  __le16 ee_len; /* extent包含的block個(gè)數(shù) */
  11.  __le16 ee_start_hi; /*extent起始block的物理地址的高16位 */
  12.  __le32 ee_start_lo; /*extent起始block的物理地址的低32位 */
  13. };//數(shù)據(jù)節(jié)點(diǎn)中的extent_body格式
  14. struct ext4_extent_idx {
  15.  __le32 ei_block; /* 索引所覆蓋的文件范圍的起始block的邏輯序號(hào) */
  16.  __le32 ei_leaf_lo; /* 存放下一級(jí)extents的block的物理地址的低32位 */ 
  17.  __le16 ei_leaf_hi; /* 存放下一級(jí)extents的block的物理地址的高16位 */
  18.  __u16 ei_unused;
  19.  
  20. };//索引節(jié)點(diǎn)中的extent_body格式

舉一個(gè)/var/log/messages文件的例子如下圖所示:

inode位圖和塊位圖

硬盤上會(huì)有專門存放塊數(shù)據(jù)的區(qū)域也會(huì)有存放inode的區(qū)域,但是當(dāng)我們要新建一個(gè)文件時(shí),就需要知道哪個(gè)inode區(qū)域和哪個(gè)塊是空的,這就需要分別用一個(gè)塊來存儲(chǔ)inode位圖和一個(gè)塊來存儲(chǔ)塊位圖,每一個(gè)bit為1表示占用,為0表示未占用。但是一個(gè)塊最多有4K*8=32K個(gè)位,也就最多能表示32K個(gè)塊的狀態(tài),所以需要讓這些塊組成一個(gè)塊組,來搭出更大的系統(tǒng)。

硬鏈接和軟鏈接

硬鏈接與原文件共用一個(gè)inode,且inode不能跨文件系統(tǒng),所以硬鏈接也不能跨文件系統(tǒng)。

軟鏈接有自己inode,只是打開文件時(shí)是指向另外一個(gè)文件,所以可以跨文件系統(tǒng)且當(dāng)原文件被刪除后仍存在。

本文最后更新于 2022-10-6 15:10,某些文章具有時(shí)效性,若有錯(cuò)誤或已失效,請(qǐng)?jiān)诰W(wǎng)站留言或聯(lián)系站長(zhǎng):17tui@17tui.com
·END·
站長(zhǎng)網(wǎng)微信號(hào):w17tui,關(guān)注站長(zhǎng)、創(chuàng)業(yè)、關(guān)注互聯(lián)網(wǎng)人 - 互聯(lián)網(wǎng)創(chuàng)業(yè)者營(yíng)銷服務(wù)中心

免責(zé)聲明:本站部分文章和圖片均來自用戶投稿和網(wǎng)絡(luò)收集,旨在傳播知識(shí),文章和圖片版權(quán)歸原作者及原出處所有,僅供學(xué)習(xí)與參考,請(qǐng)勿用于商業(yè)用途,如果損害了您的權(quán)利,請(qǐng)聯(lián)系我們及時(shí)修正或刪除。謝謝!

17站長(zhǎng)網(wǎng)微信二維碼

始終以前瞻性的眼光聚焦站長(zhǎng)、創(chuàng)業(yè)、互聯(lián)網(wǎng)等領(lǐng)域,為您提供最新最全的互聯(lián)網(wǎng)資訊,幫助站長(zhǎng)轉(zhuǎn)型升級(jí),為互聯(lián)網(wǎng)創(chuàng)業(yè)者提供更加優(yōu)質(zhì)的創(chuàng)業(yè)信息和品牌營(yíng)銷服務(wù),與站長(zhǎng)一起進(jìn)步!讓互聯(lián)網(wǎng)創(chuàng)業(yè)者不再孤獨(dú)!

掃一掃,關(guān)注站長(zhǎng)網(wǎng)微信

大家都在看

熱門排行

    最近更新

      返回頂部
      主站蜘蛛池模板: 一级毛片一级毛片一级毛片 | 五夜婷婷 | 日韩欧美卡一卡二卡新区 | 青草国产| 久久久久久网站 | 久久久久综合 | 国产又色又爽黄的网站免费 | 免费看片子| 一级毛片黄| 成人精品第一区二区三区 | 香蕉97超级碰碰碰碰碰久 | 日本片免费观看一区二区 | 精品国产一区二区三区在线 | 色免费观看| 香蕉tv亚洲专区在线观看 | 中出在线播放 | 国产精品a v 免费视频 | 国产69精品久久久久9牛牛 | 美国三级在线 | 91短视频在线观看免费 | 特黄视频 | 国产chinese视频在线观看 | 女人牲交一级毛片 | 国产福利视频在线观看 | 中国黄色片视频 | 久久五十路 | 大伊香蕉精品二区视频在线 | 久久久久久99精品 | 国产一区二区三区在线电影 | 亚洲欧美国产日产综合不卡 | 久久一区二区免费播放 | 久久精品视频在线播放 | 在线免费看网站 | xvideos中国入口 | 在线免费看片 | 成人国产在线看不卡 | 国产精品午夜性视频 | 亚洲国产视频网 | 四虎hk网址 | 日韩一级在线播放 | 日本不卡高清免费v |