大部分的Linux文件系统(如ext2、ext3)规定,一个文件由目录项、inode和数据块组成:

  • 目录项:包括文件名和inode节点号。
  • Inode:又称文件索引节点,包含文件的基础信息以及数据块的指针。
  • 数据块:包含文件的具体内容。

inode

理解inode,要从文件储存说起。文件储存在硬盘上,硬盘的最小存储单位叫做"扇区"(Sector),每个扇区储存512字节(相当于0.5KB)。

操作系统读取硬盘的时候,不会一个扇区一个扇区地读取,这样效率太低,而是一次性连续读取多个扇区,即一次性读取一个"块"(block)。这种由多个扇区组成的"块",是文件存取的最小单位。"块"的大小,最常见的是4KB,即连续八个 sector组成一个 block。

文件数据都储存在"块"中,那么很显然,我们还必须找到一个地方储存文件的元信息,比如文件的创建者、文件的创建日期、文件的大小等等。这种储存文件元信息的区域就叫做inode,中文译名为"索引节点"。

inode包含文件的元信息,具体来说有以下内容:

  • 文件的字节数。
  • 文件拥有者的User ID。
  • 文件的Group ID。
  • 文件的读、写、执行权限。
  • 文件的时间戳,共有三个:ctime指inode上一次变动的时间,mtime指文件内容上一次变动的时间,atime指文件上一次打开的时间。
  • 链接数,即有多少文件名指向这个inode。
  • 文件数据block的位置。

可以用stat命令,查看某个文件的inode信息:

总之,除了文件名以外的所有文件信息,都存在inode之中。至于为什么没有文件名,下文会有详细解释。

当查看某个文件时,会先从inode表中查出文件属性及数据存放点,再从数据块中读取数据。

看文件存储结构示意图:

inode的大小

inode也会消耗硬盘空间,所以硬盘格式化的时候,操作系统自动将硬盘分成两个区域。一个是数据区,存放文件数据;另一个是inode区(inode table),存放inode所包含的信息。

每个inode节点的大小,一般是128字节或256字节。inode节点的总数,在格式化时就给定,一般是每1KB或每2KB就设置一个inode。假定在一块1GB的硬盘中,每个inode节点的大小为128字节,每1KB就设置一个inode,那么inode table的大小就会达到128MB,占整块硬盘的12.8%。

查看每个硬盘分区的inode总数和已经使用的数量,可以使用df -i 命令。

看每个inode节点的大小,可以用如下命令: dumpe2fs -h /dev/hda | grep "Inode size"

由于每个文件都必须有一个inode,因此有可能发生inode已经用光,但是硬盘还未存满的情况。这时,就无法在硬盘上创建新文件。

inode号码

每个inode都有一个号码,操作系统用inode号码来识别不同的文件。

这里值得重复一遍,Linux系统内部不使用文件名,而使用inode号码来识别文件。对于系统来说,文件名只是inode号码便于识别的别称或者绰号。表面上,用户通过文件名,打开文件。实际上,系统内部这个过程分成三步:首先,系统找到这个文件名对应的inode号码;其次,通过inode号码,获取inode信息;最后,根据inode信息,找到文件数据所在的block,读出数据。

使用ls -i命令,可以看到文件名对应的inode号码,例如:

目录项

Linux系统中,目录(directory)也是一种文件。打开目录,实际上就是打开目录文件。
目录文件的结构非常简单,就是一系列目录项(dirent)的列表。每个目录项,由两部分组成:所包含文件的文件名,以及该文件名对应的inode号码。
ls命令只列出目录文件中的所有文件名:

ls -i命令列出整个目录文件,即文件名和inode号码

如果要查看文件的详细信息,就必须根据inode号码,访问inode节点,读取信息。ls -l命令列出文件的详细信息。

链接和软链接

硬链接
一般情况下,文件名和inode号码是"一一对应"关系,每个inode号码对应一个文件名。但是,Linux系统允许,多个文件名指向同一个inode号码。这意味着,可以用不同的文件名访问同样的内容;对文件内容进行修改,会影响到所有文件名;但是,删除一个文件名,不影响另一个文件名的访问。这种情况就被称为"硬链接"(hard link)。
ln命令可以创建硬链接,语法为: ln source_file target_file

运行上面这条命令以后,源文件与目标文件的inode号码相同,都指向同一个inode。inode信息中有一项叫做"链接数",记录指向该inode的文件名总数,这时就会增加1。反过来,删除一个文件名,就会使得inode节点中的"链接数"减1。当这个值减到0,表明没有文件名指向这个inode,系统就会回收这个inode号码,以及其所对应block区域。
这里顺便说一下目录文件的"链接数"。创建目录时,默认会生成两个目录项:"."和".."。前者的inode号码就是当前目录的inode号码,等同于当前目录的"硬链接";后者的inode号码就是当前目录的父目录的inode号码,等同于父目录的"硬链接"。所以,任何一个目录的"硬链接"总数,总是等于2加上它的子目录总数(含隐藏目录),这里的2是父目录对其的“硬链接”和当前目录下的".硬链接“。

软链接

除了硬链接以外,还有一种特殊情况。文件A和文件B的inode号码虽然不一样,但是文件A的内容是文件B的路径。读取文件A时,系统会自动将访问者导向文件B。因此,无论打开哪一个文件,最终读取的都是文件B。这时,文件A就称为文件B的"软链接"(soft link)或者"符号链接(symbolic link)。
这意味着,文件A依赖于文件B而存在,如果删除了文件B,打开文件A就会报错:"No such file or directory"。这是软链接与硬链接最大的不同:文件A指向文件B的文件名,而不是文件B的inode号码,文件B的inode"链接数"不会因此发生变化。
ln -s命令可以创建软链接,语法为: ln source_file target_file

教程:12、文件存储结构相关推荐

  1. Linux文件存储结构,包括目录项、inode、数据块

    2019独角兽企业重金招聘Python工程师标准>>> 先说inode 理解inode,要从文件储存说起.文件储存在硬盘上,硬盘的最小存储单位叫做"扇区"(Sec ...

  2. Revit API 开发(12): Revit 文件存储结构

    整理(很多内容非原创,转载自网络) 链接来自 The Building Coder: Open Revit OLE Storage RVT File Version RVT and RFA Thumb ...

  3. SQLite指南(0) 表和索引的文件存储结构

    SQLite采用的是B+树来存储表中的索引和数据.  B树的键及其值既存储在内部节点上,也存储在叶节点上,所有的叶节点具有相同的深度.  B+树作了些微改变,键和数据会存储到叶节点上,并且按照键值排好 ...

  4. linux文件存储结构,Linux文件存储方式以及软硬链接

    在Linux中,文件包括常规文件.目录.符号链接等.为了方便理解,在本文中,文件指常规文件,目录指常规目录. 文件 1. 文件是如何存储的? 文件是由3部分组成 的: 文件名: dentry 文件元数 ...

  5. git服务器文件存储结构,在远程服务器搭建gitlab,并将数据单独存储到磁盘

    虽然github目前是全球最火的分布式代码托管平台,但是github有一个缺点就是,project如果想要建为private,那就得付费.还有data存储在github平台,而不是自己的本地服务器.相 ...

  6. oracle 11g 存储结构和数据文件

    2019独角兽企业重金招聘Python工程师标准>>> 存储结构与数据文件 存储结构: database----tablespace-----sefment-----extent-- ...

  7. 存储结构和磁盘划分(基于RedHat7)

    转载来自:http://www.linuxprobe.com/chapter-06.html(良心之作) 章节简述: Linux系统中颇具特色的文件存储结构常常搞的新手头晕,本章节将从Linux系统中 ...

  8. 2.1 linux 存储结构和硬盘划分

    2.1 一切从"/"开始 Linux系统中的目录.字符设备.块设备.套接字.打印机等等都被抽象成了文件,即刘遄老师所一直强调的--Linux系统中一切都是文件.既然平时跟咱们打交道 ...

  9. 第五天学习--存储结构与磁盘划分

    章节简述: Linux系统中颇具特色的文件存储结构常常搞得新手头晕脑胀,本章将从Linux系统中的文件存储结构开始,讲述文件系统层次化标准(FHS,Filesystem Hierarchy Stand ...

最新文章

  1. 《高阶Perl》——导读
  2. oracle创建定时任务
  3. Layui layedate 弹窗插件,弹出就隐藏, 无法选择
  4. java上机题四取三排列_Java练习题
  5. 物流管理论文实现:基于遗传算法的带时间窗和载重约束的车辆路径优化
  6. boost::multiprecision模块将使用 fixed_int 的算术结果与 GMP 结果进行比较相关的测试程序
  7. linux redis安装
  8. 基于空间方法的图神经网络模型_用于时空图建模的图神经网络模型 Graph WaveNet | 课程上新...
  9. JavaScript表单
  10. 国家计算机房机柜接地图集,中国铁塔机房及室外机柜标准图集.pdf
  11. 宇电智能调节仪AIBUS 及MODBUS 通讯协议说明V8.0
  12. [一本通]题解 1031
  13. 什么是网络连接状态指示器NCSI
  14. 2022-2027年中国通信光缆市场规模现状及投资规划建议报告
  15. 一款开源好用的车辆管理系统源码,基于SSH框架和SaaS模式
  16. switch组件设置大小
  17. 【码农学编曲】贝斯的编写
  18. PyTorch GPU环境搭建 【Winds10 + Python3.6 + CUDA10.0 + PyTorch 0.4.1 (PyTroch 1.0 branch)】
  19. Ubuntu 18.04安装Adams 2021
  20. 69个微信小程序常见问题

热门文章

  1. R语言统计代码运行耗时实战:计算代码运行时间、使用proc.time函数计算代码运行时间
  2. 在决策树类相关算法中,一个接点的基尼系数通常是大于还是小于他的父节点?是总是大于还是总是小于?
  3. 回归模型(regression model)有哪些指标?如何计算回归指标(regression metrics)?如何可视化他们?
  4. DNA测序,第一代DNA测序,第二代DNA测序,第三代DNA测序,sanger法
  5. 试编写一个汇编语言程序,要求对键盘输入的小写字母用大写字母显示出来
  6. 计算机不等长编码有哪些,第9讲最佳不等长编码_W
  7. 便携式不锈钢管道焊接机器人_304不锈钢管居然可以发黑!?
  8. 【ES6】 let与const详解
  9. ubuntu 16.0.4 opencv 3.4.1 + opencv_contrib 3.4.1 cmake-gui 安装
  10. Python:生成两个日期间的随机日期