linux文件属性描述(inode,block)
1.ls -lhi
文字解释:
第一列:inode索引节点编号(人的身份证,全国唯一)
系统读取文件时首先通过文件名找到inode,然后才能读取到文件内容。
第二列:文件类型及权限(共10个字符,第一个字符为类型,后9个字符为文件权限)
第三列:硬链接个数(详细参看In命令的讲解)
第四列:文件或目录所属的用户(属主)
linux里面文件和程序的存在必须要有用户和组满足相应的存在需求。
第五列:文件或目录所属的组
第六列:文件或目录的大小
第七八九列:文件或目录的修改时间;默认月日时分
第十列:实际的文件或目录名
文件名不算文件的属性
不同Centos版本inode大小不同:
dumpe2fs /dev/sda1|grep -i "Inode size" #<==/boot分区默认128
查看文件系统inode总量以及剩余量:df -i
查看磁盘的使用量:df -h
磁盘空间是否满了,是由两项参数决定的,第一个是inode是否满了,第二个block是否满了
磁盘满的一个特征(no space on device left)
有关inode的小结:
1.磁盘被分区格式化为ext4文件系统后会生成一定数量的inode和block
2.inode称为索引节点,它的作用是存放文件的属性信息以及作为文件的索引(指向文件的实体)
3.ext3/ext4文件系统的block存放的是文件的实际内容
4.inode是磁盘上的一块存储空间,C6非启动分区inode默认大小256字节,C5是128字节
5.inode的表现形式是一串数字,不同的文件对应的inode(一串数字)在文件系统里是唯一的
6.inode节点号相同的文件,互为硬链接文件,可以认为是一个文件的不同入口
7.ext3/ext4文件系统下,一个文件被创建后至少要占用一个inode和一个block;正常情况一个文件占用且只能占用一个inode(人和身份证)
8.block是用来存储实际数据的,每个block的大小一般有1k,2k,4k几种。其中引导分区等为1k,其它普通分区多为4k(C6)
9.如果一个文件很大(高清的大片4G),可能占多个block,如果文件很小(0.01K),至少占一个block,并且这个block的剩余空间就浪费了,即无法再存储其它数据了
10.inode大小和总量查看
1)dumpe2fs /dev/sda1|egrep -i "block size | Inode size"
2)dumpe2fs /dev/sda1|egrep -i "block count | Inode count"
默认block count一般会大于Inode count的数量
11.查看inode的总量和使用量:df -i
12.查看文件的inode信息方法:ls -li 或 stat /etc/hosts
13.如何生成及指定inode大小
格式化命令:mkfs.ext4 -b 2048 -l 256 /dev/sdb
有关Block的知识小结
1.磁盘读取数据是按block为单位读取的
2.一个文件可能占用多个block。但是每读取一个blcok就会消耗一次磁盘I/O
3.如果要提升磁盘IO性能,那么就要尽可能一次性读取数据尽量的多
4.一个block只能存放一个文件的内容,无论内容有多小。如果block默认是4K大小,那么存放一个1K的文件,剩余3K就不能存放别的文件,只能浪费了
5.Block并非越大越好。block太大对于存放小文件就会浪费磁盘空间,例如:1000K的文件,block为4K,占用250个block,如果block默认为1K,则需要占用1000个block。访问效率谁更高?消耗IO分别为250次和1000次
6.根据业务需求,确认默认的block大小,如果是大文件(大于16K)一般设置block大一点,小文件(小于1K)一般设置block小一点
7.block太大,例如4K,文件都是0.1K的,大量浪费磁盘空间,但是访问性能高
8.block太小,例如1K,文件都是1000K,消耗大量磁盘IO
9.blcok大小设置也是格式化分区时候确定的,命令mkfs.ext4 -b 2048 -I 256 /dev/sdb
10.企业里文件都会比较大(一般会大于4K),block设置大一些会提升磁盘访问效率
11.ext3/ext4文件系统(Centos5和6),一般都设置为4K
总的小结:
1.磁盘被分区格式化文件系统后,会分为inode和block两部分内容
2.inode存放文件的属性以及指向文件实体的指针,文件名不在inode里,一般在上级目录的block里
3.访问文件,原理通过文件名-->inode-->block