基础IO(文件系统)

news2025/1/11 22:53:57

一、块组的宏观理解

1、分区和分组

首先一台电脑就一个磁盘,一般800GB到1TB,为了管理这么大的内存数据,我们就对磁盘进行分区,分区之后才是我们看到的C盘,D盘等。

但是其实分区之后空间还是太大不好管理,我们需要进行分组,这样才能管理好磁盘中文件数据。

这种思想就是分治。

2、理解组块

(1)Data Blocks

数据区,内存占比90%,里面存放的都是4KB大小的数据块。

(2)Block Bitmap

块位图,用比特位0,1来记录数据区的数据块是否被占用。

(3)inode Table

inode表,也是数据块,存放文件属性(大小,所有者,ACM时间,但是没有文件名)。

(4)inode Bitmap

inode位图,用比特位0,1来记录inode表中inode是否被写入。

Linux文件属性是一个大小固定的128字节的集合体

struct inode

{

        int size;

        mode_t mode;

        int datablocks[N];    记录文件占用的数据块编号,用来LBA寻址

        int inode_number;   每一个文件都有一个inode编号用来标识文件

};

指令 ll -li 显示文件inode编号。

(5)GDT Group Descriptor Table

块组描述符,描述Block Group的使用情况,是一个管理字段。

(6)SB Super Block

超级块,存放一个分区的信息,所以超级块不是每一个组块都有,也不是只有一个组块有超级块(便于数据恢复),记录Block , inode的总量,使用情况和大小等,超级块相当于一个文件系统。

(7)格式化

在每一个分区分组,然后写入文件系统的管理数据。

本质:在磁盘中写入文件系统(清空里面的数据,只剩文件系统这个框架)

二、细节问题讨论

1、inode 编号与 datablock 

inode编号在分区中是唯一的,在分区中分组就是确定每一个组块的起始inode编号和终止inode编号,拿到一个inode编号先找到对应的分区和组块,然后减去组块的起始inode编号,在bitmap中找到对应的属性和内容。datablock也是如此。

2、datablock[N]

在上文中我们提到,结构体inode中有一个datablock[N]来记录文件占据的数据块编号,在ext2下,N = 15,其中下标0~11是直接指向数据块,大小4KB,后三个下标会进行一级二级寻找数据块(利用一个或多个数据块里面存放指向其他数据块的指针的方法让文件对应的数据块增多)以此来达到扩大存放文件的作用。

3、了解目录和文件的增删查改

目录也是文件,所以目录有文件属性和文件内容,目录的属性好理解,目录的内容存放的是目录里面文件的inode与文件名的映射关系。找文件的顺序:文件名 -> 文件inode

目录的r权限:允许我们读取目录中文件名与文件inode的映射关系。

目录的w权限:创建文件后一定要向目录内容里面写入文件的文件名与文件inode映射关系。而文件的删除就是把文件对应的inode和inode_bitmap清空,但对应数据块不会清空,所以理论上如果误删文件是可以恢复出来的,但是如果误删之后做了其他操作把原来的文件对应数据块内容覆盖那就无法恢复了。

4、如何找到文件

找到文件所在目录 -> 打开目录 -> 根据文件名和inode关系找到inode -> 在inode table 找到文件属性 -> 找到文件占用数据块编号 -> LBA寻址

如何找到文件所在目录?

要根据路径逆向解析,是操作系统做的,一直解析到根目录,由于根目录名称与inode是已知的,再顺着路径依次打开目录最后找到文件。

有时我们写的代码指令是不带路径的,但是在启动进程时自带的cwd会找到当前路径,最后帮我们带上路径,这样我们才能顺利找到目录。

如何确定文件分区?

分区 -> 写入文件系统(格式化) -> 挂载到目录 -> 进入目录就能在指定分区中进行文件操作

所以目录就确定了文件在哪个分区。例如Linux中一般根目录就挂载一个分区,其下的目录文件就在这分区找。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1950670.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

习题2.23

不解释了,这么简单的题目。 (defn for-each[f item](if (not (empty? item));(println (f (first item)))(f (first item)))(if (not (empty? item))(for-each f (rest item)));(f (first item)))执行结果如下

FastGPT、Dify、Coze产品功能对比分析

在当前的人工智能领域,模型接入、应用发布、应用构建、知识库和工作流编排等功能是衡量一个AI平台综合能力的重要指标。本文将对FastGPT、Dify和Coze这三款产品的功能进行详细对比分析,以帮助用户更好地了解它。 订阅模式及市场概况 在订阅模式及市场概…

CSS常见属性详解——内边距与外边距

内边距与外边距 内边距 外边距 应用场景 在网页排版布局时,我们经常会希望元素与元素之间有一定的间距,此时我们可能会用到CSS的外边距或内边距属性,这两个属性都能让元素之间产生距离,那么他们之间有什么不同呢? …

【SpringBoot】1 Gitee

本项目 Gitee 地址:https://gitee.com/Lin_DH/system idea中可能装个gitee的插件,这样操作起来比较方便。 1)登录 Gitee 官网(https://gitee.com/),新建仓库。 2)复制新建的 Gitee 仓库地址&am…

大麦抢票-狠货

大部分购买方式已迁移至手机端,专注研究移动端 小白操作–仅供学习 注意在帐号按权重的第三方账号设置解绑淘宝,否则有可能在抢票时候出现滑块,影响抢票,抢票优先选择大麦 ⚠️核心内容参考: 据悉,在购票环节&…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] LYA的朋友排队(100分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 💻 ACM银牌🥈| 多次AK大厂笔试 | 编程一对一辅导 👏 感谢大家的订阅➕ 和 喜欢💗 🍿 最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,支持题目在线…

深入分析 Android ContentProvider (五)

文章目录 深入分析 Android ContentProvider (五)ContentProvider 的性能优化和实践案例1. 性能优化技巧1.1. 数据库索引优化示例:添加索引 1.2. 批量操作与事务管理示例:批量插入操作 1.3. 使用异步操作示例:使用 AsyncTask 进行异步查询 1.…

FastAPI(七十八)实战开发《在线课程学习系统》接口开发-- 评论

源码见:"fastapi_study_road-learning_system_online_courses: fastapi框架实战之--在线课程学习系统" 梳理下思路 1.判断是否登录 2.课程是否存在 3.如果是回复,查看回复是否存在 4.是否有权限 5.发起评论 首先新增pydantic模型 class Cour…

如何为 DigitalOcean 上的托管数据库收集可观测指标

DigitalOcean 在 2024 年 5 月开始支持在托管数据库(PostgreSQL、MySQL、Redis和Kafka)中收集可观测指标。我们将在本偏内容中,告诉大家如何使用部署在 DigitalOcean App Platform 上的网络应用程序,为 DigitalOcean 上的 Postgre…

C语言 | Leetcode C语言题解之第283题移动零

题目&#xff1a; 题解&#xff1a; void swap(int *a, int *b) {int t *a;*a *b, *b t; }void moveZeroes(int *nums, int numsSize) {int left 0, right 0;while (right < numsSize) {if (nums[right]) {swap(nums left, nums right);left;}right;} }

新手必备:iPhone新机官网验机流程详解

目录 一、准备工作 二、外包装检查 三、序列号查询 四、开箱验机 五、开机验机 六、功能检测 七、售后服务验证 八、总结 一、准备工作 检查包裹&#xff1a;确保快递包裹完好无损。准备录像设备&#xff1a;使用另一台设备录制整个验机过程&#xff0c;以防日后发生纠…

C# 贪吃蛇游戏

贪吃蛇游戏可分为手动玩法和自动玩法 冯腾飞/贪吃蛇

海山数据库(He3DB)性能优化方案解析

前端优化是一个永恒的话题&#xff0c;每个前端开发者都希望自己的页面能够快速加载&#xff0c;给用户良好的体验。但往往事与愿违。因此&#xff0c;本文从编码优化、构建优化、部署优化三方面入手进行web页面性能优化。 1. 编码优化 1.1. Css优化 1.1.1. 合理使用css选择…

昇思25天学习打卡营第33天|共赴算力时代

文章目录 一、平台简介二、深度学习模型2.1 处理数据集2.2 模型训练2.3 加载模型 三、共赴算力时代 一、平台简介 昇思大模型平台&#xff0c;就像是AI学习者和开发者的超级基地&#xff0c;这里不仅提供丰富的项目、模型和大模型体验&#xff0c;还有一大堆经典数据集任你挑。…

QSqlQuery增删改查

本文记录使用QSqlQuery实现增删改查的过程。 目录 1. 构建表格数据 声明变量 表格、数据模型、选择模型三板斧设置 列表执行查询 列表的水平表头设置 2. 新增一行 构建一个空行 通过dialog返回的修改行数据&#xff0c;update更新 3. 更新一行 获取到需要更新的行 通…

qt--电子相册

一、项目要求 设计一个电子相册&#xff0c;点击上一张&#xff0c;切换到上一张图片&#xff0c;点击下一张&#xff0c;切换到下一张图片。 要求&#xff1a;图片的展示可以循环&#xff08;QList<QString>&#xff09; 要求&#xff1a;界面美观 二、项目代码 本质是通…

力扣141环形链表问题|快慢指针算法详细推理,判断链表是否有环|龟兔赛跑算法

做题链接 目录 前言&#xff1a; 一、算法推导&#xff1a; 1.假设有环并且一定会相遇&#xff0c;那么一定是在环内相遇&#xff0c;且是快指针追上慢指针。 2.有环就一定会相遇吗&#xff1f;快指针是每次跳两步&#xff0c;有没有可能把慢指针跳过去&#xff1f; 3.那一定…

ffmpeg更改视频的帧率

note 视频帧率调整 帧率(fps-frame per second) 例如&#xff1a;原来帧率为30&#xff0c;调整后为1 现象&#xff1a;原来是每秒有30张图像&#xff0c;调整后每秒1张图像&#xff0c;看着图像很慢 实现&#xff1a;在每秒的时间区间里&#xff0c;取一张图像…

数据库 第五次作业

1.触发器 建立两个表:goods(商品表)、orders(订单表)并 在商品表中导入商品记录 建立触发器&#xff0c;订单表中增加订单数量后&#xff0c;商品表商品数量同步减少对应的商品订单出数量,并测试 建立触发器&#xff0c;实现功能:客户取消订单&#xff0c;恢复商品表对应商品的…

Llama 3.1 这一最强模型按时降临!扎克伯格最新的访谈表明:Llama 将会成为 AI 领域中的 Linux 。

&#x1f431; 个人主页&#xff1a;TechCodeAI启航&#xff0c;公众号&#xff1a;TechCodeAI &#x1f64b;‍♂️ 作者简介&#xff1a;2020参加工作&#xff0c;专注于前端各领域技术&#xff0c;共同学习共同进步&#xff0c;一起加油呀&#xff01; &#x1f4ab; 优质专…