在Linux中,inode是一个重要的概念,是理解Unix/Linux文件系统和磁盘储肆胡存的基础。
理解inode,要从文件储存说起。
文件储存在硬盘上,硬盘的最小存储单位叫做扇区,每个扇区储存512字节,相当于0.5KB。
*** 作系统读取磁盘的时候,不会一个一个扇区地读取,这样效率太低,而是一次性连续读取多个扇区,即一次读取一个块。这种由多个扇区组成的块,是文件存取的最小单位。块的大小,最常见的是4KB,即连续八个sector组成一个block。
文件数据都存储在块中,很显然,我们还必须找到一个地方储存文件的元信息,比如文件的创建者、文件的创建日期、文件的大小等。这种储存文件元信息的区域就叫做inode,中文译名为索引节点。
每一个文件都有对应的inode,里面包含了与该文件有扒州关的一些信息。
接下来,我为大家简述一下Linux文件系统通过i节点把文件的逻辑结构和物理结构转换的工作过程:
Linux通过inode节点表将文件的逻辑结构和物理结构进行转换。
inode节点是一个64字节长的表,表中包含了文件的相关信息,其中有文件的大小、文件所有者、文件的存取许可方式以及文件的类型等重要信息。在inode节点表中最重要的内容裂此拦是磁盘地址表。在磁盘地址表中有13个块号,文件将以块号在磁盘地址表中出现的顺序依次读取相应的块。
Linux文件系统通过把inode节点和文件名进行连接,当需要读取该文件时,文件系统在当前目录表中查找该文件名对应的项,由此得到该文件相对应的inode节点号,通过该inode节点的磁盘地址表把分散存放的文件物理块连接成文件的逻辑结构。
1.分区和目录
1.2 inode的大小
iNode也占用硬盘空间,格式化时, *** 作系慎瞎统将硬盘分为两个区域,一个是数据区,一个是inode区。
每个inode大小为128或者256byte。一个目录下能建多少文件,受限于所在目录分区的inode数量。
1.3 inode节点号
每个inode都有一个inode节点号,os用iNode来识别不同文件。
Linux内部不使用文件名而使用inode号码来识别文件。
系统打开宽铅空文件过程:
-- 1 根据文件名找到inode号码;
-- 2 通过inode号码,获取inode信息;
-- 3 根据inode信息,找到文件数据所在block,进行读取。
1.4 目录项
目录也是文件,打开目录,其实是打开目录文件。
目录是目录项的列表,每个目录项由两部分组成:所含文件的文件名 + 该文件名对应的inode节点号。
ls -i 可以列出整个目录文件,即文件名和inode号码。
1.5
1.5.1 touch一个新空文件占用磁盘空间情况?
空文件也占用磁盘空间,占用一个inode的大小。
1.5.2 新建一个空目激悉录占用磁盘空间情况?
目录也是占用一个inode节点,block的大小,典型为4k
1.5.3 新建大小为1K的文件,实际占用多大磁盘空间?
系统分配空间以block为最小单位,因此实际占用一个inode(一般为256byte)和1个block(4k)
1.5.4 向 *** 作系统发起读取2byte的文件,实际读取多少?
系统一次性读取一个block,4KB的内容。这就是程序的局部性原理。
与硬链接区别就是 :文件A指向的是文件B的文件名,而不是iNode,这样B的iNode引用数量不会有改变。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)