美文网首页
Linux文件系统简单模型

Linux文件系统简单模型

作者: 我不懂我不懂a | 来源:发表于2020-04-14 21:46 被阅读0次

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

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

    目录树模型

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

    目录树

    文件存储模型

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

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

    目录树模型

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

    目录树

    文件存储模型

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


    • 超级块用来存放文件系统本身的结构信息:每个区域的大小,未被使用的磁盘块的信息等。
    • i-节点表, 用于保存文件的属性:大小,修改时间,文件所有者等信息。还记录了文件数据所在的数据区块的序列号。
    • 数据区就是保存数据的,文件的数据被分成一个或多个块保存在数据区中,编码保存在i-节点表中。

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

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

    大文件是如何保存的?

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

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

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

    相关文章

      网友评论

          本文标题:Linux文件系统简单模型

          本文链接:https://www.haomeiwen.com/subject/vfuxvhtx.html