Linux文件系统简单模型

2020-04-14  本文已影响0人  我不懂我不懂a

这篇文章实际上记录的是《Unix/Linux》编程实践教程中的Unix文件系统内部结构

要理解两个模型,一个是目录树模型,一个是文件存储模型。
理解存储设备抽象成文件系统。

目录树模型

在UNIX/Linux中,目录是一种特殊的文件,它是由文件和目录的序列组成,一定有"." 和 ".." 来指向本目录和父目录。根目录"/"的“..”指向自己本身。各级目录组成了树状的结构。

目录树

文件存储模型

实际上记录的是《Unix/Linux》编程实践教程中的Unix文件系统内部结构

要理解两个模型,一个是目录树模型,一个是文件存储模型。
理解存储设备抽象成文件系统。

目录树模型

在UNIX/Linux中,目录是一种特殊的文件,它是由文件和目录的序列组成,一定有"." 和 ".." 来指向本目录和父目录。根目录"/"的“..”指向自己本身。各级目录组成了树状的结构。

目录树

文件存储模型

磁盘被抽象成分区,扇区是磁盘上的基本存储单元,给磁盘块(扇区?)编号,成为文件系统的序列块。磁盘块组成的空间又可以分成3部分(每个空间都由多个磁盘块组成):超级块,i-节点块,数据区。


目录树加上文件内部结构的使用。
可以看到目录下有个文件名叫uselist的项,该项还有个属性保存了i-节点的编号47,看到47可以看到uselist的i-节点保存了数据区的627,200,992编号,说明这三个磁盘块都是保存了userlist的文件数据。

我们可以通过 ls -ia [目录] 来查看文件的i-节点(可以看到根目录的 “.”,“..”都指向了同一个i-节点)

大文件是如何保存的?

i-文件的分配列表有13个分配数据块编号的空间。如果文件太大,需要14个数据块存放怎么办?
unix采用了一种间接块的方法,当数据块超过10个的时候,第11个分配列表开始保存的就是间接块的地址。间接块就是一个数据块,但是它不存储真实的数据而是保存了真实数据块的地址。

第12个分配列表空间又不一样,它是二级间接块(字面理解),就相当多了一级。
第13个列表空间是三级间接块。

ps:这里有点绕,图文一起理解吧,看不懂就只能看书的解释了。

上一篇下一篇

猜你喜欢

热点阅读