[ext4]空间管理 - 查找块
在文件系统中,当需要执行写操作时,肯定是需要查找需要写入的块。那么如何查找块哪?
在Ext4系统中,有两个函数是可能执行查找操作的:ext4_getblk()、ext4_get_block()。
其中ext4_getblk(),原型如下:
structbuffer_head *ext4_getblk(handle_t *handle, struct inode *inode,
ext4_lblk_tblock, int create, int *errp)
该函数的主要功能:基于给定的inode,查找或创建block,并返回与其映射的buffer;create标识用于表示当查找不到时,是否执行分配块操作。
本节我们不关注块分配操作;因此create为0。
ext4_get_block()函数原型如下:
intext4_get_block(struct inode *inode, sector_t iblock,
struct buffer_head *bh, int create)
该函数的主要功能:基于给定的inode,查找文件的逻辑块iblock,并将其与bh进行映射,如果没有查找到,若create为1,则执行块分配操作为文件申请新的block,然后再与bh建立映射。这个函数用于适配VFS层接口。
无论ext4_getblk()还是ext4_get_block(),都是先初始化structext4_map_blocks map,然后调用函数ext4_map_blocks(),实现块查找功能。
先来看一下ext4_map_blocks这个结构体:
struct ext4_map_blocks{
ext4_fsblk_t m_pblk;
ext4_lblk_t m_lblk;
unsigned int m_len;
unsigned int m_flags;
};
在分析ext4_map_blocks结构体之前,我们先来熟悉两个概念:物理块号、逻辑块号。对于一个存储设备(这个设备是可以是存储分区)格式化为某个文件系统的过程中,一般,都会给予给定的block值对整个存储分区划分很多个大小为block size的单元,每个单元,我们都称之为块,每一个块都有一个块号,是以存储分区起始位置为偏移计算的,我们一般称之为物理块号。当某一个块被分配给某一个文件用来存放Data后,那么这个块给予文件起始位置又被赋予了一个块号,这个块号只对于该文件有效,这个块号我们一般称之为逻辑块号。
ext4_map_blocks结构体主要用来描述需要映射的空间信息,包含映射空间的物理块号,逻辑块号,空间大小,属性标识。在查找之前,一般都是知道逻辑块号和空间大小的。
ext4_map_blocks()的原型如下:
intext4_map_blocks(handle_t *handle, struct inode *inode,
struct ext4_map_blocks *map, int flags)
1.首先调用ext4_es_lookup_extent()查找extent status tree,extent status tree是描述extent在内存中信息与状态的树,可以理解为extent
tree在内存的中组织。在查找extent status tree的过程中,先检查cache extents是否满足条件,否则遍历整个extent status tree。
2.如果在缓存中没有查找到,那么我们就需要从磁盘上读出extent tree数据,然后查找。实现函数为ext4_ext_find_extent()。那么是如何实现的哪?
说起来,也十分的简单。
由前述[磁盘布局extent tree]可知,extent tree在磁盘上都是以extent block为单位存储的。
首先从inode中找出根节点,在根节点中的四个entry中通过二分法查找包含指定block的entry,然后通过该entry信息读取下一级extent
block到buffer中。该buffer中包含很多entry,继续通过二分法查找包含指定block的enrty,然后再读取下一级entry,依次类推;直至到叶子节点或无下级的节点。
从而我们得到与制定block最相近的extent(若查找不到,则返回小于block的最大的extent,即左侧的extent).
假如寻找到合适的包含block块号的extent,则计算出对应的物理block和在这个extent中以block为起始点到extent终点的长度(如果这个长度大约所要求的长度,则取所要求的长度)。
out:
if (allocated > map->m_len)
allocated = map->m_len;
ext4_ext_show_leaf(inode, path);
map->m_flags |= EXT4_MAP_MAPPED;
map->m_pblk = newblock;
map->m_len = allocated;
如果没有找到块,因为之前的Create标识已经说明即使没有找到,也不需要创建,所以直接返回0.
OK,块查找操作分析结束。
作者:Younger Liu,
本作品采用知识共享署名-非商业性使用-相同方式共享 3.0 未本地化版本许可协议进行许可。
[ext4]空间管理 - 查找块的更多相关文章
- [ext4]空间管理 - 与分配相关的关键数据结构
在块分配机制中,涉及到几个主要的数据结构. 通过ext4_allocation_request描述块请求,然后基于块查找结果即上层需求来决定是否执行块分配操作. 在分配过程中,为了更好执行分配, ...
- [ext4]空间管理 - 分配机制
在Ext4系统中,存在很多分配策略,比如预分配.多块分配.延迟分配等 Prealloc预分配 在ext4系统中,对于小文件和大文件的空间申请请求,都有不同的分配策略.对用小文件的空间请求,e ...
- [ext4]13 空间管理 - Prealloc分配机制
作者:Younger Liu, 本作品采用知识共享署名-非商业性使用-相同方式共享 3.0 未本地化版本许可协议进行许可. 在ext4系统中,对于小文件和大文件的空间申请请求,都有不同的分配策略 ...
- Oracle表空间管理
oracle表空间相关常用命令小结: 1.ALTER DATABASE SET DEFAULT BIGFILE TABLESPACE; //修改表空间数据文件类型 2.ALT ...
- 本地管理表空间(LMT)与自动段空间管理(ASSM)概念
创建表空间时,extent management local 定义本地管理表空间(LMT),segment space management auto 定义自动段空间管理(ASSM). extent ...
- ORACLE表空间管理维护
1:表空间概念 在ORACLE数据库中,所有数据从逻辑结构上看都是存放在表空间当中,当然表空间下还有段.区.块等逻辑结构.从物理结构上看是放在数据文件中.一个表空间可由多个数据文件组成. 如下图所示, ...
- ORACLE表空间管理方式segment和extent
A permanent tablespace contains persistent schema objects. Objects in permanent tablespaces are stor ...
- 【Oracle】表空间管理
--表空间管理为主.附带 权限管理.数据字典 /* 表空间是逻辑结构,数据文件是物理结构 一个表空间对应多个段segment 段可以对应多个数据文件.跨磁盘 一个段对应多个盘区 extent 一个盘区 ...
- Oracle数据库体系结构(7) 表空间管理1
表空间是Oracle数据库最大的逻辑存储结构,有一系列段构成.Oracle数据库对象存储结构的管理主要是通过表空间的管理实现的. 1.表空间的分类 表空间根据存储类型不同分为系统表空间和非系统表空间 ...
随机推荐
- Azure Messaging-ServiceBus Messaging消息队列技术系列5-重复消息:at-least-once at-most-once
上篇博客中,我们用实际的业务场景和代码示例了Azure Messaging-ServiceBus Messaging对复杂对象消息的支持和消息的持久化: Azure Messaging-Service ...
- dreamweaver中的 map怎么调用?_制作热点图像区域
我们浏览网页时,经常看到一些图片上会出现特别的超链接,即在一张图片上有多个局部区域和不同的网页链接,比如地图链接. 这就是映射图像(Image Map),它是指一幅根据链接对象不同而被人为划分为若干指 ...
- 配置远程服务器,使hyper-v能够连接网络
一般远程服务器只有一个网卡和IP,如果你要在服务器上装虚拟机,那么要使虚拟机能够连接网络,必须要创建虚拟交换机. 如果创建虚拟交换机并桥接,那么就会改变IP地址,改变IP地址,就连接不上远程服务器.造 ...
- angular element()
使用angular.element()获取一个dom的方法. 1.可以使用jquery的选择器 2.可以使用javascript的原生的的查找元素的方法 下面是angular.element()提供的 ...
- PHP之流程的控制
在一个公司中,员工肯定会有高层.中层和普通员工的,这样如果在某个公司员工遇到某种问题,需要请假.或者提一些请求的时候,就会需要去申请,申请的时候有的是可以直接和上级申请的,有时比较重要的事情,是 ...
- Azure Messaging-ServiceBus Messaging消息队列技术系列6-消息回执
上篇博文中我们介绍了Azure Messaging的重复消息机制.At most once 和At least once. Azure Messaging-ServiceBus Messaging消息 ...
- iOS开发之NSOperation & NSOperationQueue
1.简介 (1) NSOperationQueue(操作队列)是由GCD提供的队列模型的Cocoa抽象,是一套Objective-C的API,为了使并发(多线程)编程变得更加简单,但效率比GCD略低. ...
- shell学习指南-阅读笔记
shell学习指南真不是刚开始学习shell应该看得书,虽然其中讲了简单的linux命令,shell语法等,但是每章也有些深入和生僻地方,我想如果我刚学shell看到这样的地方一定会头疼的要死.或许也 ...
- webpack独立打包与缓存处理
关于 微信公众号:前端呼啦圈(Love-FED) 我的博客:劳卜的博客 知乎专栏:前端呼啦圈 前言 先前写了一篇webpack入门的文章<webpack入门必知必会>,简单介绍了webpa ...
- Error--解决使用Application Loader提交ipa包审核时的报错:ERROR ITMS-90168: "The binary you uploaded was invalid."
在提交iTunes Connect审核时,使用Application Loader提交ipa包时报错:ERROR ITMS-90168: "The binary you uploaded w ...