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一个文件的过程????

不同角度说明文件系统

软硬链接

相关推荐
x***r15112 小时前
Redis Desktop Manager 0.8.8 安装教程(Windows redis-desktop-manager-0.8.8.384详细步骤)
数据库·windows·redis
initialize130612 小时前
Postgresql(Oracle兼容) 到Oracle19.9字符语义
数据库·oracle
稷下元歌12 小时前
七天学会plc 加机器视觉完整笔记:S7-1200 数据类型、存储区与寻址方式(I/Q/M/DB 详解)。
网络·数据库·笔记
潮起鲸落入海12 小时前
mysql 5.x源码安装
数据库·mysql
睡不醒男孩03082313 小时前
第一篇:多云与多模态时代的企业级数据库云管理平台(DBaaS)选型指南
数据库·clup·中启乘数
小二·13 小时前
向量数据库实战
数据库
炘爚13 小时前
Phase 5:MySQL 连接池
数据库·mysql
j_xxx404_14 小时前
MySQL库操作硬核解析:字符集、校验规则、大小写比较、备份恢复与连接排查
运维·服务器·数据库·人工智能·mysql·ai·oracle
minji...14 小时前
MySQL数据库 (五) MySQL表的约束(上),非空约束,默认值约束,零填充约束,主键约束,符合主键
数据库·mysql·表的约束·主键约束·非空约束·复合主键·零填充约束
拾贰_C14 小时前
【python | installation 】python 安装 | Windows | 命令使用
linux·数据库·ubuntu