文件系统与inode

简介: 文件系统与inode

文章目录

文件=文件内容+文件属性

一个文件没有被打开。那么这个文件就在磁盘里面存放着

磁盘是:我们计算机中的一个机械设备(SSD,FLASH卡,USB)

扇区:同心园中一道一道的以小块区域,

磁道:每一快同心园

柱面:半径相同的扇形围起来构成的一圈

磁盘写入的基本单位:扇区! 512字节

定位方式:

可以把磁盘想象成线性结构,LBA可以理解为数组的下标,访问地址,如果我们要写到物理地址,我们就要转换成为物理地址

类比(虚拟地址和物理地址)

大磁盘管理成本就非常高

先要把磁盘划分成一个有一个的小区域

  1. 分区:磁盘中就是分区(C盘D 盘),新加卷,把大盘分解成好几个盘(大磁盘变成小空间)
  2. 格式化::分区写入文件系统: 类比我们给每个省,写入省政府领导班子,(格式化)—》更换领导班子,(更换文件系统)

Linux特有的ext系列的文件系统

super block:里面存放的是每个空间的使用情况,是描述整个分区的相关文件系统信息(可以理解为做了一个备份),避免其他的super block坏掉

group describe table: 描述组的情况,inode bitmap和data bitmap中使用的情况,没有用多少,

一个文件包含文件数据和文件属性,

data block里面存放的就是文件数据(4kb)

inode block里面存放的就是文件的属性(512b)

inode都被存放在了inode table里面

inode

我们可以通过inode的编号找到文件

 struct inode
 {
//文件的所有属性(文件大小,文件权限,文件的拥有者,所属组,文件的编号inode)
//数据信息  int inode number
//int block[32]//用数组的方式把和inode关联的写到inode里面
}

找到一个文件的inode就可以找到他的所有属性,

block是通过映射关系找到器对应的数据块

bitmap

位图

block bitmap

inode bitmap

00001010

从右向左:

比特位的位置含义:inode 编号

比特位内容含义: 特定的inode是否有被占用,


将inode bitmap加载到内存中,找到一个没有被使用的inode(使用位操作)找到里面为0的位置,将其使用

同理对于,block bitmap(对数据块的使用情况,未进行数据的申请释放,遍历5个为0 的位置,在填如到inode里面)

inode操作

目录是文件吗

目录是文件,他也是有inode,里面的文件大小,权限,所有人,所属组也都是有的,同样,目录也是有数据的

目录中的数据存放这将目录中的文件名映射到对应inode编号,我们创建的文件一定是在特定的目录当中

touch a
echo hello > a
cat a

这一系列的操作


我们通过inode bitmap找到未被使用的位,inode

我们再把文件的相关信息全都存放进去

写入: 再block bitmap里面看未被使用的block,建立映射关系,把数据写入到相应的块中

查看: 再当前目录下,把hello.c和新的inode的映射关系查找到,查找到相应的文件

假如我们mkdir demo

在里面查找inode=1234的hello.c

我们通过inode把数据映射到当前路径之下,


维护1234的inode的hello.c的映射关系—> 找到inode=1234----> 在inode table里面找到对应的inode --> 就可以找到了对应的block 数据块—>再打印文件内容


然而

rm hello.c并不是按照上述流程来操作的

他不需要inode table 将上述的操作把inode bitmap给清掉 即可

把所有的数据块清掉

(属性数据和内容数据都还在),—>(恢复文件,把inode bitmap把曾经的位由0置1就可以了,同理block)

:rm并不是删除文件的属性和数据,只是把其是否有有效位给置去了


如果我们误操作了,删除了文件,最好的做法是什么??

什么东西都没有,找人

实际上: 我们创建了一个文件,实在inode table里面创建了一个节点,然后再数据区里面,找多个数据块,进行维护,,然后再inode里面数据和属性建立关系

软硬链接

软连接相当于一个快捷方式,方便我们查找一个路径

  1. 创建软链接
ln -s [file] [lname]


2. 删除链接

unlink [链接名]

软连接是有独立的inode 的说明他就是一个独立文件,,有自己的属性集合,和数据块,数据块里面保存的是指向文件的所在路径+文件名

  1. 创建硬链接
    硬链接本质上就不是一个独立的文件,而是一个文件名和inode编号的映射关系,因为自己没有独立的inode,所以就没有所谓的属性数据



创建硬链接,本质是在特定的路径下,填写一对文件名和inode的映射关系,相当于完成了重命名,




ref就是有多少个硬链接数

建立硬链接数就是ref++,就是叫做引用计数

ref=0的时候就才把这个文件给删除掉

相关文章
|
存储 负载均衡 算法
p2p的文件系统
p2p的文件系统
142 4
|
11天前
|
存储 Unix PHP
31 文件系统
路老师分享PHP文件处理技术,涵盖文件的打开、关闭、读取及写入操作,帮助初学者深入了解PHP语言。
25 2
|
存储 数据可视化 Linux
文件系统-
文件系统-
74 0
|
存储 缓存 算法
文件系统(下)
文件系统(下)
170 0
|
存储 缓存 算法
文件系统(上)
文件系统(上)
184 0
|
存储 Linux Windows
【文件系统】
【文件系统】
100 0
|
Linux 程序员 Shell
sysfs文件系统与kobject
sysfs文件系统与kobject
163 0
|
存储 Linux 索引
Linux文件系统inode的作用
前面学习了磁盘管理中的磁盘分区,以及逻辑卷,交换分区的创建,这篇文章将介绍一下我们在分区以及格式化时候用到的ext4文件系统,本盘文章的学习内容包括了解索引(index)和块(block)的作用。
127 0
|
存储 Linux Windows
理解文件系统/inode的概念/磁盘/软硬链接
本文目标:⭐理解文件系统中inode的概念⭐认识软硬链接,对比区别。讲解了文件系统,加深了对文件的理解,与此同时对于磁盘的理解也有很大的帮助!
理解文件系统/inode的概念/磁盘/软硬链接
|
存储 Unix Linux