校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Linux中的EXT系列文件系統格式詳解

Linux中的EXT系列文件系統格式詳解

熱門標簽:高德地圖標注無營業執照 廣州電銷機器人系統圖 金融行業外呼線路 東莞人工智能電銷機器人供應商 百度地圖標注要不要錢 長沙開福怎么申請400電話 智能電話機器人線路 賀州市地圖標注app 江蘇電銷外呼防封系統是什么

Linux文件系統

常見的硬盤如上圖所示,每個盤片分多個磁道,每個磁道分多個扇區,每個扇區512字節,是硬盤的最小存儲單元,但是在操作系統層面會將多個扇區組成塊(block),是操作系統存儲數據的最小單元,通常是8個扇區組成4K字節的塊。
對于Linux文件系統,需要考慮以下幾點:

  • 文件系統需要有嚴格的組織形式,使文件能夠以塊為單位存儲
  • 文件系統需要有索引區,方便查找一個文件分成的多個塊存在了什么位置
  • 如果有文件近期經常被讀寫,需要有緩存層
  • 文件應該用文件夾的形式組織起來方便管理和查詢
  • Linux內核要在自己的內存里維護一套數據結構,保持哪些文件被哪些進程打開和使用

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

  • - 表示普通文件
  • d 表示文件夾
  • c 表示字符設備文件
  • b 表示塊設備文件
  • s 表示套接字socket文件
  • l 表示軟鏈接

Inode和塊存儲

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

struct ext4_inode {
 __le16 i_mode;  /* File mode */
 __le16 i_uid;  /* Low 16 bits of Owner Uid */
 __le32 i_size_lo; /* Size in bytes */
 __le32 i_atime; /* Access time */
 __le32 i_ctime; /* Inode Change time */
 __le32 i_mtime; /* Modification time */
 __le32 i_dtime; /* Deletion Time */
 __le16 i_gid;  /* Low 16 bits of Group Id */
 __le16 i_links_count; /* Links count */
 __le32 i_blocks_lo; /* Blocks count */
 __le32 i_flags; /* File flags */
 union {
  struct {
   __le32 l_i_version;
  } linux1;
  struct {
   __u32 h_i_translator;
  } hurd1;
  struct {
   __u32 m_i_reserved1;
  } masix1;
 } osd1;    /* OS dependent 1 */
 __le32 i_block[EXT4_N_BLOCKS];/* Pointers to blocks */
 __le32 i_generation; /* File version (for NFS) */
 __le32 i_file_acl_lo; /* File ACL */
 __le32 i_size_high;
 __le32 i_obso_faddr; /* Obsoleted fragment address */
 union {
  struct {
   __le16 l_i_blocks_high; /* were l_i_reserved1 */
   __le16 l_i_file_acl_high;
   __le16 l_i_uid_high; /* these 2 fields */
   __le16 l_i_gid_high; /* were reserved2[0] */
   __le16 l_i_checksum_lo;/* crc32c(uuid+inum+inode) LE */
   __le16 l_i_reserved;
  } linux2;
  struct {
   __le16 h_i_reserved1; /* Obsoleted fragment number/size which are removed in ext4 */
   __u16 h_i_mode_high;
   __u16 h_i_uid_high;
   __u16 h_i_gid_high;
   __u32 h_i_author;
  } hurd2;
  struct {
   __le16 h_i_reserved1; /* Obsoleted fragment number/size which are removed in ext4 */
   __le16 m_i_file_acl_high;
   __u32 m_i_reserved2[2];
  } masix2;
 } osd2;    /* OS dependent 2 */
 __le16 i_extra_isize;
 __le16 i_checksum_hi; /* crc32c(uuid+inum+inode) BE */
 __le32 i_ctime_extra; /* extra Change time (nsec << 2 | epoch) */
 __le32 i_mtime_extra; /* extra Modification time(nsec << 2 | epoch) */
 __le32 i_atime_extra; /* extra Access time (nsec << 2 | epoch) */
 __le32 i_crtime; /* File Creation time */
 __le32 i_crtime_extra; /* extra FileCreationtime (nsec << 2 | epoch) */
 __le32 i_version_hi; /* high 32 bits for 64-bit version */
 __le32 i_projid; /* Project ID */
};

其中__le32 i_block[EXT4_N_BLOCKS]存儲了到數據塊的引用,EXT4_N_BLOCKS定義如下:

#define EXT4_NDIR_BLOCKS 12
#define EXT4_IND_BLOCK EXT4_NDIR_BLOCKS
#define EXT4_DIND_BLOCK (EXT4_IND_BLOCK + 1)
#define EXT4_TIND_BLOCK (EXT4_DIND_BLOCK + 1)
#define EXT4_N_BLOCKS (EXT4_TIND_BLOCK + 1)

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

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

struct ext4_extent_header {
 __le16 eh_magic; /* ext4 extents標識:0xF30A */
 __le16 eh_entries; /* 當前層級中有效節點的數目 */
 __le16 eh_max; /* 當前層級中最大節點的數目 */
 __le16 eh_depth; /* 當前層級在樹中的深度,0為葉子節點,即數據節點,>0代表索引節點 */
 __le32 eh_generation; 
}
struct ext4_extent {
 __le32 ee_block; /* extent的起始block邏輯序號 */
 __le16 ee_len; /* extent包含的block個數 */
 __le16 ee_start_hi; /*extent起始block的物理地址的高16位 */
 __le32 ee_start_lo; /*extent起始block的物理地址的低32位 */
};//數據節點中的extent_body格式
struct ext4_extent_idx {
 __le32 ei_block; /* 索引所覆蓋的文件范圍的起始block的邏輯序號 */
 __le32 ei_leaf_lo; /* 存放下一級extents的block的物理地址的低32位 */ 
 __le16 ei_leaf_hi; /* 存放下一級extents的block的物理地址的高16位 */
 __u16 ei_unused;

};//索引節點中的extent_body格式

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

inode位圖和塊位圖

硬盤上會有專門存放塊數據的區域也會有存放inode的區域,但是當我們要新建一個文件時,就需要知道哪個inode區域和哪個塊是空的,這就需要分別用一個塊來存儲inode位圖和一個塊來存儲塊位圖,每一個bit為1表示占用,為0表示未占用。但是一個塊最多有4K*8=32K個位,也就最多能表示32K個塊的狀態,所以需要讓這些塊組成一個塊組,來搭出更大的系統。

硬鏈接和軟鏈接

硬鏈接與原文件共用一個inode,且inode不能跨文件系統,所以硬鏈接也不能跨文件系統。

軟鏈接有自己inode,只是打開文件時是指向另外一個文件,所以可以跨文件系統且當原文件被刪除后仍存在。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

標簽:永州 洛陽 廊坊 玉樹 松原 張家界 北京 滄州

巨人網絡通訊聲明:本文標題《Linux中的EXT系列文件系統格式詳解》,本文關鍵詞  Linux,中的,EXT,系列,文件,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Linux中的EXT系列文件系統格式詳解》相關的同類信息!
  • 本頁收集關于Linux中的EXT系列文件系統格式詳解的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    成人性生交大合| 亚洲精品在线网站| 一区二区在线观看免费| 日本久久一区二区| 成人动漫在线一区| 三级久久三级久久| 亚洲视频香蕉人妖| 国产精品天天摸av网| 久久99久久精品| 亚洲va欧美va人人爽午夜| 久久夜色精品一区| 国产精品77777竹菊影视小说| 精品少妇一区二区三区在线播放| 日韩国产精品大片| 波多野结衣在线一区| 欧洲精品一区二区三区在线观看| 5566中文字幕一区二区电影| 国产一区二区网址| 亚洲国产精品久久人人爱 | 欧美日韩国产不卡| 亚洲国产综合色| 久久亚区不卡日本| 欧美视频在线一区| 国产经典欧美精品| 日韩va亚洲va欧美va久久| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 成人一二三区视频| 亚洲一二三区在线观看| 久久精品夜色噜噜亚洲a∨| 欧美怡红院视频| 一本久久精品一区二区| 国产精品一区二区在线观看不卡| 婷婷亚洲久悠悠色悠在线播放| 国产精品高潮呻吟久久| 国产精品色婷婷久久58| 久久综合网色—综合色88| 欧美一区二区高清| 亚洲综合一区二区精品导航| 欧美最新大片在线看| 国产一区二区91| 国产色产综合色产在线视频| 2024国产精品视频| 亚洲精品视频在线| 99精品视频在线观看| 日韩精品一区二区三区视频播放 | 日韩理论片一区二区| 成人的网站免费观看| 中文字幕一区二区三| 欧美综合在线视频| 亚洲第一成人在线| 日韩一区二区三区视频| 制服丝袜亚洲色图| 91麻豆精品国产91| 91精品国产欧美一区二区成人| 91麻豆精品视频| 欧美视频一区二区三区在线观看| 日本久久电影网| 日韩视频永久免费| 26uuu色噜噜精品一区| 另类小说一区二区三区| 精品卡一卡二卡三卡四在线| 波多野结衣亚洲一区| 亚洲在线中文字幕| 久久亚洲私人国产精品va媚药| 国产九九视频一区二区三区| 欧美色综合久久| 欧美日韩在线三区| 欧美日韩大陆在线| 麻豆精品一区二区三区| 欧美成人在线直播| 一本到不卡免费一区二区| 午夜国产精品影院在线观看| 欧美videos大乳护士334| 国产成人免费高清| 亚洲成人激情社区| 中文字幕av一区二区三区| 欧美猛男gaygay网站| 高清日韩电视剧大全免费| 亚洲超碰精品一区二区| 欧美国产激情二区三区| 欧美va亚洲va国产综合| 欧美在线综合视频| av一区二区三区黑人| 国内精品在线播放| 日本亚洲欧美天堂免费| 夜夜精品视频一区二区| 1000部国产精品成人观看| 日韩免费成人网| 日韩女优av电影在线观看| 欧美日韩国产一级片| 欧美日韩精品一区二区在线播放| 99久久99久久精品国产片果冻| 国产自产v一区二区三区c| 奇米888四色在线精品| 视频一区国产视频| 亚洲一区二区三区小说| 一本久久综合亚洲鲁鲁五月天 | 经典三级一区二区| 欧美区视频在线观看| 日韩av高清在线观看| 中文字幕av一区 二区| 国产精品性做久久久久久| 国产一区久久久| 免费看日韩精品| 亚洲第一主播视频| 亚洲精品一二三四区| 中文字幕日韩av资源站| 久久精品亚洲精品国产欧美 | 国内精品伊人久久久久av一坑 | 91精品国产aⅴ一区二区| 色婷婷综合五月| av不卡在线观看| 99re视频精品| 99在线精品免费| 91伊人久久大香线蕉| 99国产精品99久久久久久| 成人av综合在线| 99在线视频精品| 色综合久久综合网97色综合| 94-欧美-setu| 欧美性色黄大片| 欧美日韩高清不卡| 日韩欧美在线综合网| 精品成人佐山爱一区二区| 精品福利视频一区二区三区| 国产色产综合产在线视频| 中文子幕无线码一区tr| 亚洲欧美一区二区三区国产精品| 中文字幕一区二区三区不卡在线| 亚洲欧洲av在线| 亚洲国产欧美日韩另类综合| 天堂一区二区在线| 麻豆国产精品官网| 成人深夜在线观看| 一本大道av一区二区在线播放 | 97精品久久久午夜一区二区三区 | 一区二区成人在线| 午夜激情一区二区三区| 久久不见久久见中文字幕免费| 国产高清不卡一区| 色94色欧美sute亚洲13| 在线综合+亚洲+欧美中文字幕| 欧美精品一区二区蜜臀亚洲| 亚洲欧洲成人精品av97| 日本午夜一本久久久综合| 成人小视频免费观看| 欧美色手机在线观看| 精品国产乱码久久久久久蜜臀 | 精品精品国产高清一毛片一天堂| 久久久久久久久久久久电影| 国产精品色婷婷久久58| 精品盗摄一区二区三区| 精品成人佐山爱一区二区| 麻豆精品国产91久久久久久| 91丨九色丨尤物| 精品少妇一区二区三区日产乱码 | 一级特黄大欧美久久久| 国产在线观看免费一区| 国产精品污www在线观看| 日韩你懂的在线播放| 国产精品久久福利| 三级一区在线视频先锋 | 爽好久久久欧美精品| 国产成人8x视频一区二区| 欧美美女喷水视频| 亚洲视频免费在线| 国产伦精品一区二区三区免费| 欧美在线小视频| 国产精品午夜春色av| 裸体歌舞表演一区二区| 欧美日韩免费高清一区色橹橹| 欧美高清一级片在线观看| 另类中文字幕网| 欧美丰满一区二区免费视频| 亚洲伦理在线精品| 国产精品亚洲综合一区在线观看| 在线电影国产精品| 亚洲制服欧美中文字幕中文字幕| 国产91清纯白嫩初高中在线观看 | 亚洲欧洲综合另类在线 | 久久精品免费观看| 欧美日韩免费一区二区三区| 亚洲日本乱码在线观看| 成人av在线看| 久久亚洲免费视频| 久99久精品视频免费观看| 91精品久久久久久久91蜜桃| 亚洲综合丝袜美腿| 91美女片黄在线| 亚洲丝袜另类动漫二区| 成人av综合在线| 中文字幕人成不卡一区| 成人午夜激情在线| 亚洲国产精品成人综合| 国产福利91精品| 欧美国产乱子伦| 成人污污视频在线观看| 中文字幕日韩一区二区| 99re8在线精品视频免费播放| 亚洲国产高清不卡|