linux 索引节点 inode 详解

1 inode简介     

理解inode,要从文件储存说起。     

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

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

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

2 inode的内容     

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

* 文件的字节数     

* 文件拥有者的User ID    

* 文件的Group ID     

* 文件的读、写、执行权限     

* 文件的时间戳,共有三个:ctime指inode上一次变动的时间,mtime指文件内容上一次变动的时间,atime指文件上一次打开的时间。     

* 链接数,即有多少文件名指向这个inode     

* 文件数据block的位置      

可以用stat命令,查看某个文件的inode信息: [plain] view plain copy [root@localhost /]# stat example.txt       总之,除了文件名以外的所有文件信息,都存在inode之中。至于为什么没有文件名,下文会有详细解释。 

3 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命令。

猜你喜欢

转载自blog.csdn.net/youmatterhsp/article/details/80055141