Ext文件系统

引言

我们研究的这个文件和以前的IO文件有什么区别

聊聊硬件

机械磁盘是计算机唯一的一个机械设备

1.2磁盘存储结构

1.3磁盘的逻辑结构

1.4真实过程

柱面是一个逻辑上的概念,其实就是每一个面上,相同半径的磁道逻辑上构成的柱面

所以,磁盘物理上分了很多面,但是逻辑上,磁盘整体是由"柱面"卷起来的

所以,磁盘的真实情况是:

磁道:

某一盘面的某一个磁道展开:

柱面:

整个磁盘所有盘面的同一个磁道展开,柱面展开:

整盘:

整个磁盘就是多张二维的扇区数组表(三维数组?)

所以,寻找一个扇区:先找到哪一个柱面(Cylinder),在确定柱面内的哪一个磁道(其实就是磁头位置,Head),在确定扇区(Sector),所以就有了CHS

操作系统只需要使用LBA!!!LBA地址转换为CHS地址,CHS地址转换为LBA地址。磁盘将这两个地址互相转换!

1.5CHS地址&&LBA地址

CHS->LBA

LBA=柱面号C*单个柱面的扇区总数(磁头数*每磁道扇区数)+磁头号H*每磁道扇区数+扇区号S-1

CHS地址->扇区号是从1开始的。柱面和磁道都是从0开始的编号的。

LBA地址是从0开始的

总柱面,磁道个数,扇区总数等信息,在磁盘内自动维护,上机开始会获取到这些参数。

LBA转换CHS

柱面号C=LBA //(磁头数*每磁道扇区数)后面的这个就是单个柱面的扇区总数

磁头号H=(LBA%(磁头数*每磁道扇区数))//每磁道扇区数

扇区号S=(LBA%每磁道扇区数)+1

磁盘内部自己可以实现CHS和LBA的转换。

所以,从现在这个角度看磁盘就是一个一维数组,数组的下标就是每一个扇区的LBA地址。os使用磁盘,就可以使用一个数字访问扇区。

正式开启文件系统

三小问

如何判断处于分区

分区写入文件系统,无法直接使用,需要于特定的目录关联,进行挂载才能使用。

所以,可以根据目标文件的路径前缀,判断我在哪一个分区

内存中的路径缓存结构

  • 每个文件都要有对应的dency文件,所有被打开的文件,就可以在内存中形成树形结构
  • 整个树形结构也会同时属于LRU结构中,进行节点淘汰。
  • 整个结构也会属于Hash,方便于查找。
  • 整个树形结构,在内存整体构成了Linux的路径缓存结构,打开访问文件,首先在这颗树下根据路径进行查找,找到就返回属性inode和内容没找到就从磁盘加载路径,添加dentry结构,缓存新路径。

fopen一个文件的过程????

不同角度说明文件系统

软硬链接

相关推荐
V1ncent Chen16 小时前
SQL大师之路 13 聚合函数和分组
数据库·sql·mysql·数据分析
赵渝强老师16 小时前
【赵渝强老师】高斯数据库(openGauss)的体系架构
数据库·postgresql·opengauss·gaussdb·国产数据库
IvorySQL16 小时前
开源同行,感谢有你|IvorySQL 社区邀您领取贡献者证书
数据库·postgresql·开源
IvorySQL16 小时前
PostgreSQL 技术日报 (3月19日)|当 AI 代理开始批量创建数据库
数据库·postgresql·开源
2401_8747325317 小时前
Python上下文管理器(with语句)的原理与实践
jvm·数据库·python
l1t17 小时前
与系统库同名python脚本文件引起的奇怪错误及其解决
开发语言·数据库·python
星空露珠17 小时前
迷你世界UGC3.0脚本Wiki角色模块管理接口 Actor
开发语言·数据库·算法·游戏·lua
IpdataCloud17 小时前
指纹浏览器为什么要自建IP检测?基于IP数据云离线库的架构实践
数据库·网络协议·tcp/ip·架构·edge浏览器
翻斗包菜17 小时前
MySQL 从入门到精通:数据库核心知识与实战指南
数据库·mysql
grizzliesster218 小时前
MySQL——表的约束
数据库·mysql