文件系统与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的文件系统
164 4
|
存储 缓存 安全
virtiofs per-inode DAX 介绍
## 背景信息 1. 什么是 virtiofs? virtiofs 是一种用于在 host/guest 之间共享文件的文件系统,由 Redhat 开源,它使得不同 guest 之间能够以快速、一致、安全的方式共享同一个 host 目录树结构,目前广泛应用于 Kata Container 作为容器的 rootfs。 2. 什么是 DAX? DAX (Direct Access) 最初是针对于
2673 0
virtiofs per-inode DAX 介绍
|
2月前
|
存储 Unix PHP
31 文件系统
路老师分享PHP文件处理技术,涵盖文件的打开、关闭、读取及写入操作,帮助初学者深入了解PHP语言。
34 2
|
存储 缓存 Linux
sysfs文件系统(1)
sysfs是一种虚拟文件系统,旨在提供一种访问内核数据结构的方法,从而允许用户空间程序查看和控制系统的设备和资源。sysfs文件系统通常被挂载在/sys目录下。sysfs提供了一种以树状结构组织的系统信息的方式,其中每个设备都有一个唯一的目录来表示它自己,其中包含有关设备的各种属性和状态信息的文件。这些文件通常是只读的,但有些也可以用于修改设备的某些设置。sysfs还提供了一个机制来通知用户空间程序有关设备状态更改的信息,从而使其能够对这些更改做出反应。sysfs文件系统被广泛用于Linux内核中,它为开发者提供了一种简单的方式来管理和控制系统中的各种设备和资源。
223 0
|
存储 数据可视化 Linux
文件系统-
文件系统-
81 0
|
存储 缓存 算法
文件系统(上)
文件系统(上)
196 0
|
存储 缓存 算法
文件系统(下)
文件系统(下)
176 0
|
存储 Linux Windows
【文件系统】
【文件系统】
109 0
|
存储 Linux 索引
Linux文件系统inode的作用
前面学习了磁盘管理中的磁盘分区,以及逻辑卷,交换分区的创建,这篇文章将介绍一下我们在分区以及格式化时候用到的ext4文件系统,本盘文章的学习内容包括了解索引(index)和块(block)的作用。
150 0
|
存储 Linux Windows
理解文件系统/inode的概念/磁盘/软硬链接
本文目标:⭐理解文件系统中inode的概念⭐认识软硬链接,对比区别。讲解了文件系统,加深了对文件的理解,与此同时对于磁盘的理解也有很大的帮助!
理解文件系统/inode的概念/磁盘/软硬链接