亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網(wǎng)管 > 服務器 > 正文

[ext4]12分配機制-關鍵的數(shù)據(jù)結構

2020-05-27 13:20:33
字體:
來源:轉載
供稿:網(wǎng)友

   在塊分配機制中,涉及到幾個主要的數(shù)據(jù)結構。

  通過ext4_allocation_request描述塊請求,然后基于塊查找結果即上層需求來決定是否執(zhí)行塊分配操作。

  在分配過程中,為了更好執(zhí)行分配,記錄一些信息,需要對分配行為進行描述,就有結構體ext4_allocation_contex。

  在搜尋可用空間過程中,是有可能使用預分配空間的,因此還需要有能夠描述預分配空間大小等屬性的描述符ext4_prealloc_space。

  下面,對各個關鍵結構體進行詳細的分析。

  1. 塊請求描述符ext4_allocation_request

  塊分配請求屬性,有請求描述符ext4_allocation_request來描述:

  structext4_allocation_request {

  /* target inode for block wereallocating */

  struct inode *inode;

  /* how many blocks we want to allocate*/

  unsigned int len;

  /* logical block in target inode */

  ext4_lblk_t logical;

  /* the closest logical allocated blockto the left */

  ext4_lblk_t lleft;

  /* the closest logical allocated blockto the right */

  ext4_lblk_t lright;

  /* phys. target (a hint) */

  ext4_fsblk_t goal;

  /* phys. block for the closest logicalallocated block to the left */

  ext4_fsblk_t pleft;

  /* phys. block for the closest logicalallocated block to the right */

  ext4_fsblk_t pright;

  /* flags. see above EXT4_MB_HINT_* */

  unsigned int flags;

  };

  這個請求描述符結構體在ext4_ext_map_blocks()中初始化(注:ext4_ext_map_blocks()的作用是查找或分配指定的block塊,并完成與緩存空間的映射)。

  具體上述信息也就一個成員變量goal值的我們分析一下,goal記錄是物理塊號,其隱含含義比較重要:goal雖然只是記錄物理塊號,但是這個物理塊號的選擇可以很大程度的是文件保證locality特性及其物理地址連續(xù)性。

  goal是由函數(shù)ext4_ext_find_goal()來定義:

  static ext4_fsblk_t ext4_ext_find_goal(struct inode*inode,

  struct ext4_ext_path *path,

  ext4_lblk_t block)

  {

  if(path) {

  intdepth = path->p_depth;

  structext4_extent *ex;

  /*

  * Try to predict block placement assuming thatwe are

  * filling in a file which will eventually be

  * non-sparse --- i.e., in the case of libbfdwriting

  * an ELF object sections out-of-order but in away

  * the eventually results in a contiguousobject or

  * executable file, or some database extendinga table

  * space file. However, this is actually somewhat

  * non-ideal if we are writing a sparse filesuch as

  * qemu or KVM writing a raw image file that isgoing

  * to stay fairly sparse, since it will end up

  * fragmenting the file systems free space. Maybe we

  * should have some hueristics or some way toallow

  * userspace to pass a hint to file system,

  * especially if the latter case turns out tobe

  * common.

  */

  ex= path[depth].p_ext;

  if(ex) {

  ext4_fsblk_text_pblk = ext4_ext_pblock(ex);

  ext4_lblk_text_block = le32_to_cpu(ex->ee_block);

  if(block > ext_block)

  returnext_pblk + (block - ext_block);

  else

  returnext_pblk - (ext_block - block);

  }

  /*it looks like index is empty;

  * try to find starting block from index itself*/

  if(path[depth].p_bh)

  returnpath[depth].p_bh->b_blocknr;

  }

  /*OK. use inodes group */

  returnext4_inode_to_goal_block(inode);

  }

  細細分析這段代碼,如果從根目錄到指定邏輯塊的path存在,那么就需要根據(jù)path來計算目標物理塊的地址。

  (1) Path的終點若是dataextent,則說明該path是從根到葉子的。當請求block號大于path葉子extent的起始邏輯塊號ext_block (對應物理塊號為pblk),其邏輯塊的距離為(block-ext_block),為在最可能上保證對應物理地址的連續(xù)性;只需返回與pblk+(block-ext_block)物理塊號最接近的空閑物理塊即可;而對于請求block號小于extent的起始邏輯塊號ext_block的情況,只需盡最可能以pblk-( ext_block -block)物理塊號為目標尋找與其物理地址最接近的空閑物理塊即可。因此,我們指定goal分別為pblk+(block-ext_block)和pblk-(block-ext_block)。

  (2) 而如果path存在,卻沒有葉子,那則么辦,很簡單,我們只需要將goal物理塊號指定為最后一個的extent block對應的物理塊號既可。

  (3) 還有一種情況,沒有給出path。個人認為,這種場景即inode剛create的情況。有專門的ext4_inode_to_goal_block()來實現(xiàn):

  ext4_fsblk_t ext4_inode_to_goal_block(struct inode*inode)

  {

  structext4_inode_info *ei = EXT4_I(inode);

  ext4_group_tblock_group;

  ext4_grpblk_tcolour;

  intflex_size = ext4_flex_bg_size(EXT4_SB(inode->i_sb));

  ext4_fsblk_tbg_start;

  ext4_fsblk_tlast_block;

  block_group= ei->i_block_group;

  if(flex_size >= EXT4_FLEX_SIZE_DIR_ALLOC_SCHEME) {

  /*

  * If there are at leastEXT4_FLEX_SIZE_DIR_ALLOC_SCHEME

  * block groups per flexgroup, reserve thefirst block

  * group for directories and special files. Regular

  * files will start at the second blockgroup. This

  * tends to speed up directory access andimproves

  * fsck times.

  */

  block_group&= ~(flex_size-1);

  if(S_ISREG(inode->i_mode))

  block_group++;

  }

  bg_start= ext4_group_first_block_no(inode->i_sb, block_group);

  last_block= ext4_blocks_count(EXT4_SB(inode->i_sb)->s_es) - 1;

  /*

  * If we are doing delayed allocation, we dontneed take

  * colour into account.

  */

  if(test_opt(inode->i_sb, DELALLOC))

  returnbg_start;

  if(bg_start + EXT4_BLOCKS_PER_GROUP(inode->i_sb) <= last_block)

  colour= (current->pid % 16) *

  (EXT4_BLOCKS_PER_GROUP(inode->i_sb)/ 16);

  else

  colour= (current->pid % 16) * ((last_block - bg_start) / 16);

  returnbg_start + colour;

  }

  其思想是:如果flex_size至少有EXT4_FLEX_SIZE_DIR_ALLOC_SCHEME個block groups,則定義inode所在flex_group的第二個block group的首個可用block為起始物理塊號bg_block。

  當然,如果該flex_group的所有文件都以bg_block為goal的,肯定會產(chǎn)生競爭,所以增加color的作用,目的就是加入一個隨機值,降低可能帶來的競爭。

  因此,最后這種情況的goal會選擇inode所在flex_group中某個隨機值。

  【說明:如果flex_size只有不小于EXT4_FLEX_SIZE_DIR_ALLOC_SCHEME,則才有可能將flex_group中第一個group分離出來,用于專門存放directories和一些特殊文件,普通文件從第二個group中分配,該特可以加速directory的訪問及fsync效率?!?/p>

  2. 分配行為描述符ext4_allocation_contex

  在分配過程中,為了更好執(zhí)行分配,記錄一些信息,需要對分配行為進行描述,就有結構體ext4_allocation_contex:

  struct ext4_allocation_context{

  struct inode *ac_inode;

  struct super_block *ac_sb;

  /* original request */

  struct ext4_free_extent ac_o_ex;

  /* goal request (normalized ac_o_ex) */

  struct ext4_free_extent ac_g_ex;

  /* the best found extent */

  struct ext4_free_extent ac_b_ex;

  /* copy of the best found extent takenbefore preallocation efforts */

  struct ext4_free_extent ac_f_ex;

  __u16 ac_groups_scanned;

  __u16 ac_found;

  __u16 ac_tail;

  __u16 ac_buddy;

  __u16 ac_flags; /* allocation hints */

  __u8 ac_status;

  __u8 ac_criteria;

  __u8 ac_2order; /* if request is to allocate 2^N blocks and

  * N > 0, the field stores N, otherwise 0 */

  __u8 ac_op; /* operation, for history only */

  struct page *ac_bitmap_page;

  struct page *ac_buddy_page;

  struct ext4_prealloc_space *ac_pa;

  struct ext4_locality_group *ac_lg;

  };

  這個數(shù)據(jù)結構用來描述分配上下文的屬性。基于結構體ext4_allocation_request,由函數(shù)ext4_mb_initialize_context()進行初始化。

  ext4_mb_initialize_context()主要工作: 利用請求描述符的信息初始化ac->ac_o_ex:申請的邏輯塊號fe_logical、goal所在的group,goal的cluster號(暫時理解為物理塊號);然后將ac_g_ex 賦值為ac_o_ex。

  ext4_mb_normalize_request()會對ext4_allocation_contex結構體進行normalization:

  1.計算file的大小size應該是i_size_read(ac->ac_inode)和(offset+請求長度)中的大值,其中offset是有指定block轉化而來。

  2. 根據(jù)已定的算法估算文件可能的大小;

  #define NRL_CHECK_SIZE(req, size, max, chunk_size)

  (req<= (size) || max <= (chunk_size))

  /*first, try to predict filesize */

  /*XXX: should this table be tunable? */

  start_off= 0;

  if(size <= 16 * 1024) {

  size= 16 * 1024;

  }else if (size <= 32 * 1024) {

  size= 32 * 1024;

  }else if (size <= 64 * 1024) {

  size= 64 * 1024;

  }else if (size <= 128 * 1024) {

  size= 128 * 1024;

  }else if (size <= 256 * 1024) {

  size= 256 * 1024;

  }else if (size <= 512 * 1024) {

  size= 512 * 1024;

  }else if (size <= 1024 * 1024) {

  size= 1024 * 1024;

  }else if (NRL_CHECK_SIZE(size, 4 * 1024 * 1024, max, 2 * 1024)) {

  start_off= ((loff_t)ac->ac_o_ex.fe_logical >>

  (21- bsbits)) << 21;

  size= 2 * 1024 * 1024;

  }else if (NRL_CHECK_SIZE(size, 8 * 1024 * 1024, max, 4 * 1024)) {

  start_off= ((loff_t)ac->ac_o_ex.fe_logical >>

  (22- bsbits)) << 22;

  size= 4 * 1024 * 1024;

  }else if (NRL_CHECK_SIZE(ac->ac_o_ex.fe_len,

  (8<<20)>>bsbits,max, 8 * 1024)) {

  start_off= ((loff_t)ac->ac_o_ex.fe_logical >>

  (23- bsbits)) << 23;

  size= 8 * 1024 * 1024;

  }else {

  start_off= (loff_t)ac->ac_o_ex.fe_logical << bsbits;

  size =ac->ac_o_ex.fe_len << bsbits;

  }

  size= size >> bsbits;

  start= start_off >> bsbits;

  由此可見,預估文件大小之后得到的size和start肯定比原來的要大一些。

  3. check一下,是否覆蓋了已有的prealloc空間。(如果覆蓋,那就BUG);

  4. 更新ac_g_ex:根據(jù)(2)中size和start更新ac_g_ex;

  ac->ac_g_ex.fe_logical= start;

  ac->ac_g_ex.fe_len= EXT4_NUM_B2C(sbi, size);

  由上可見,通過ext4_mb_normalize_request()函數(shù)主要更新了ac->ac_g_ex成員。

  而ac->ac_b_ex是在ext4_mb_regular_allocator()函數(shù)初始化的,其表示可以分配的最佳的extent;隱含意思,就是就按這么分配。

  而ac-> ac_f_ex是在prealloc空間初始化之前保留ac_b_ex的副本,在ext4_mb_new_inode_pa()或ext4_mb_new_group_pa()中定義。

  3. 預分配空間描述符ext4_allocation_contex

  描述預分配空間大小等屬性的描述符ext4_prealloc_space:

  structext4_prealloc_space {

  struct list_head pa_inode_list;

  struct list_head pa_group_list;

  union {

  struct list_head pa_tmp_list;

  struct rcu_head pa_rcu;

  } u;

  spinlock_t pa_lock;

  atomic_t pa_count;

  unsigned pa_deleted;

  ext4_fsblk_t pa_pstart; /*phys. block */

  ext4_lblk_t pa_lstart; /*log. block */

  ext4_grpblk_t pa_len; /*len of preallocated chunk */

  ext4_grpblk_t pa_free; /* howmany blocks are free */

  unsigned short pa_type; /* pa type.inode or group */

  spinlock_t *pa_obj_lock;

  struct inode *pa_inode; /*hack, for history only */

  };

  其中有四個結構體非常重要:

  pa_lstart -> prealloc 空間的起始邏輯地址(對文件而言);

  pa_pstart -> prealloc 空間的起始物理地址;

  pa_len -> prealloc 空間的長度;

  pa_free -> prealloc 空間的可用長度;

  這個結構體是在函數(shù)ext4_mb_new_inode_pa()或ext4_mb_new_group_pa()中初始化。

  暫時就分析這么幾個結構體吧。

  作者:Younger Liu,

  本作品采用知識共享署名-非商業(yè)性使用-相同方式共享 3.0 未本地化版本許可協(xié)議進行許可。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
天干天干啦夜天干天2019| 亚洲美腿欧美激情另类| 色噜噜狠狠一区二区| 国产精品亚洲视频在线观看| 精品久久久久亚洲| 欧美亚洲系列| 色网址在线观看| 蜜桃av免费观看| 黄页网站在线| 久久精品网站免费观看| 91精品视频免费在线观看| 在线视频这里只有精品| 国产最新精品视频| 欧美13一14另类| 91精品国产综合久久香蕉| 牛夜精品久久久久久久| 国产影视精品一区二区三区| 欧美大片高清| 一级片手机在线观看| 性生活一级大片| 成人欧美一区二区三区的电影| 色琪琪原网站亚洲香蕉| 日韩精品免费视频人成| 欧美尤物巨大精品爽| h网站在线播放| 国产精品久久久午夜夜伦鲁鲁| 在线免费视频a| 精品黑人一区二区三区观看时间| 亚洲精品麻豆| 欧美做爰性欧美大fennong| 天堂在线观看视频| 99精品免费观看| 国产福利片在线| 视频一区二区在线观看| 制服丝袜日韩| 日本三级久久| 中文在线最新版天堂| 国产最新视频在线观看| 欧美视频在线免费看| 国产亚洲成av人片在线观看桃| 欧美做爰啪啪xxxⅹ性| 国产美女自慰在线观看| 青娱乐国产视频| 天天躁日日躁狠狠躁超碰2020| 最新日韩av在线| 波多野结衣一区二区三区四区| 性欧美free| 亚洲欧洲一级| 在线国产情侣| 亚洲视频电影图片偷拍一区| 波多野结衣在线观看一区| 特黄特黄一级片| yw193.com尤物在线| 你懂的视频网| 亚洲精品中文字幕乱码无线| 夜夜未满十八勿进的爽爽影视| 午夜久久福利视频| 亚洲性图久久| 亚洲成年人在线| 这里视频有精品| 先锋影音在av资源看片| 亚洲狠狠爱一区二区三区| 殴美一级黄色片| 亚洲国产精品91| 国产成人精品一区二区三区视频| 影音先锋中文字幕一区二区| 免费观看国产精品视频| 国产精品白嫩白嫩大学美女| 亚洲综合色视频| 美女做暖暖视频免费在线观看全部网址91| 精品麻豆一区二区三区| 国产伦子伦对白视频| 国产精品一区二区三区在线免费观看| 欧美做受高潮电影o| 亚洲精品久久久狠狠狠爱| 在线观看麻豆视频| 国产日韩中文在线中文字幕| 欧美日韩亚洲一区二区三区在线观看| 国产裸体永久免费无遮挡| 国产精品9999久久久久仙踪林| 天天综合中文字幕| 欧美国产欧美综合| 日本91av在线播放| 中文字幕一区二区av| 91麻豆精品激情在线观看最新| 中文字幕黄色av| 日韩在线视频免费| 久久女同互慰一区二区三区| 91麻豆精品国产91久久久久| 国产一级黄色av| 日韩经典一区二区三区| 亚洲理论电影网| 亚洲综合图片区| 无码人妻aⅴ一区二区三区玉蒲团| 欧美另类videos| 亚洲一级二级片| 免费电影网站在线观看| 久久久久久国产精品久久| 看全色黄大色黄大片免责看的| 成人av在线播放网址| 自产国语精品视频| 黑人巨大精品欧美一区二区一视频| 欧美在线播放一区| 懂色av中文一区二区三区天美| 亚洲中文字幕无码爆乳av| 成人涩涩小片视频日本| 久久国产精品第一页| 少妇一级淫免费观看| 围产精品久久久久久久| 国产富婆一级全黄大片| 日韩一级完整毛片| 亚洲影视一区二区三区| 91老司机精品视频| 中文文字幕文字幕高清| 欧美人善zozσ性伦交| 天干夜天天夜天干天ww| 91丝袜呻吟高潮美腿白嫩在线观看| 在线观看免费视频污| 国产精品久久久久久久久久久久冷| 在线观看a视频| 999久久久国产999久久久| 亚洲亚裔videos黑人hd| 蜜桃精品一区二区三区| 中文字幕超碰在线| 女人爱爱视频| 有坂深雪av一区二区精品| 日本黄xxxxxxxxx100| 久久国产精品久久久久久电车| 欧美 日本 国产| 欧美中文一区二区三区| 亚洲高清资源综合久久精品| 国产综合亚洲精品一区二| 国产久草在线| 亚洲精品日韩综合观看成人91| 91在线看国产| 超碰在线成人| 亚洲图片欧美视频| 国产原创视频在线观看| 国产成人免费观看网站| 国产精品欧美精品| 欧美a视频在线| 色综合一本到久久亚洲91| 久久久久女人精品毛片九一| 91九色综合久久| 成人频在线观看| 亚洲欧洲自拍偷拍| 亚洲成色www久久网站| 亚洲精品男人的天堂| 91麻豆精品久久久久蜜臀| 高清一区在线观看| 国产在线一区二区三区| 九九在线视频| 国产91丝袜在线播放0| 性欧美亚洲xxxx乳在线观看| 特黄特色大片免费视频大全| 老司机免费视频一区二区三区| 精品精品国产三级a∨在线| 成人国产精品一区二区| 亚洲欧美日韩国产一区二区| 精品无码人妻一区二区免费蜜桃| 成人在线电影网站| 91丨九色丨蝌蚪丨少妇在线观看| 亚洲怡红院在线| 欧美大片大片在线播放| 欧美一级淫片免费视频黄| 三妻四妾的电影电视剧在线观看| 天堂午夜在线| 91野花视频| 国产中文字幕在线视频| 天天综合天天色| 国产经典自拍视频在线观看| 精品国产无码在线观看| 少女频道在线观看免费播放电视剧| 天天操天天舔天天干| 国产精品视频观看| 国产美女在线免费观看| 寂寞少妇一区二区三区| 欧美在线观看一区二区| 日本成人黄色网| 99这里都是精品| 亚洲人成在线观看网站高清| a毛片在线看免费观看| 国产日韩在线观看av| 激情成人开心网| 在线电影中文日韩| 性一交一乱一色一免费无遮挡| 国产成+人+日韩+欧美+亚洲| 黄色精品一区二区| 亚洲人成亚洲人成在线观看图片| 中文字幕一区二区三区在线观看| 免费视频二区| 在线日韩成人| 毛片基地黄久久久久久天堂| 欧美激情中文字幕乱码免费| 99久久久无码国产精品衣服| 亚洲一区二区五区| 蜜桃视频网站在线| 成人网址大全| 18久久久久久| 国产粉嫩在线观看| 国产精品久久久一区二区| 国产精品毛片| 久久久久久久九九九九| 国产精品久久国产精麻豆99网站| 香蕉97视频观看在线观看| 天堂√在线中文官网在线| 成人欧美一区二区三区视频xxx| 成人h片在线播放免费网站| 欧美日韩一区二区三区在线视频| 裤袜国产欧美精品一区| 国产成人免费9x9x人网站视频| 欧美激情久久久久久久久久久| 先锋影音欧美| 一区二区三区国产视频| 俄罗斯精品一区二区| 免费视频网站在线观看入口| 亚洲男女性事视频| 国产亚洲第一伦理第一区| 亚州欧美一区三区三区在线| 国产精品九九九九九九| 国产精品人妻一区二区三区| 九九热线有精品视频99| 精品日韩一区二区| 一二三区中文字幕| 国产精品xxx在线观看| 色综合网站在线| 国产在线观看你懂的| 在线天堂一区av电影| 91亚洲精品丁香在线观看| 91麻豆福利| aaa欧美日韩| 亚洲日本乱码在线观看| 欧美日韩国产999| 精品在线观看一区二区| 国产精品成人一区二区三区电影毛片| 九义人在线观看完整免费版电视剧| 99re这里只有精品视频首页| www.日本精品| 少妇精品在线| 国产亚洲一区二区三区| 日韩在线黄色| 欧美大片专区| 日本网站在线播放| 色播在线观看| 日韩免费在线免费观看| va亚洲va日韩不卡在线观看| 久久狠狠久久综合桃花| 国内精品卡一卡二卡三| 水蜜桃亚洲精品| 欧美激情xxxxx| 先锋影视中文字幕| 精品国产一二三区| 综合久久久久| 亚洲综合激情网| 国产精品成人一区二区三区电影毛片| 老太脱裤让老头玩ⅹxxxx| av第一福利大全导航| 免费一级肉体全黄毛片| 欧美日本韩国国产| 欧美色xxx| 国产精品自产拍在线观看中文| 少妇一区二区三区| 亚洲熟妇av日韩熟妇在线| 亚洲午夜18毛片在线看| 国产精品三级在线| 亚洲xxxx视频| 久久久久久久综合| 欧美aⅴ一区二区三区视频| 鲁丝一区二区三区免费| 一级黄色免费看| 久久精品色欧美aⅴ一区二区| 亚洲国产一区二区在线| 日韩精品免费视频人成| 国产毛片av| jizzjizz亚洲中国少妇| 亚洲激情五月| 午放福利视频在线播放| 国产真实乱偷精品视频免| 黄色免费一级视频| 国产精品香蕉在线观看| 色94色欧美一区| 精品日韩久久久| 日本伦理一区二区| 成人在线一区二区三区| 免费一级黄色大片| 欧美交换国产一区内射| 欧美日韩视频第一区| 香港欧美日韩三级黄色一级电影网站| 老熟妇高潮一区二区三区| 国产情人节一区| 国产一区二区三区四区尤物| 美女网站在线观看| 日本熟妇成熟毛茸茸| 高清在线视频不卡| 国产电影一区二区在线观看| 国产午夜精品在线观看| 精品免费久久久| 国产肥臀一区二区福利视频| 高清1区2区| 国产成人精品aa毛片| 欧美成人精品欧美一级| 欧美极度另类videos高清| 色噜噜狠狠一区二区三区狼国成人| 另类视频欧美| 精品香蕉视频| 四虎精品影院在线观看视频| 日本www在线播放| 香蕉久久久久久久av网站| 欧洲精品久久久久毛片完整版| 99热在线免费观看| 久久涩涩网站| 91精品国产乱码久久久久| 国产综合色一区二区三区| 制服丝袜日韩国产| 在线香蕉视频| 精品亚洲综合| xxxx影院| 综合国产视频| 日韩成人在线视频观看| 少妇人妻大乳在线视频| 国产高清在线免费| 91成人福利在线观看| 国产·精品毛片| 制服.丝袜.亚洲.中文.综合懂| 中文字幕这里只有精品| 国产美女视频免费观看下载软件| 老司机精品视频一区二区| 1000部精品久久久久久久久|