关于linux 系统inode快耗尽问题处理!

一、inode是什么?

要想理解inode,要从文件储存说起。
文件储存在硬盘上,硬盘的最小存储单位叫做"扇区"(Sector)。每个扇区储存512字节(相当于0.5KB)。操作系统读取硬盘的时候,不会一个个扇区地读取,这样效率太低,而是一次性连续读取多个扇区,即一次性读取一个"块"(block)。这种由多个扇区组成的"块",是文件存取的最小单位。"块"的大小,最常见的是4KB,即连续八个 sector组成一个 block。文件数据都储存在"块"中,必定有一个地方储存文件的元信息,比如文件的创建者、文件的创建日期、文件的大小等等。这种储存文件元信息的区域就叫做inode,中文译名为"索引节点"。每一个文件都有对应的inode,里面包含了与该文件有关的一些信息。

二、inode的内容

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

* 文件的字节数
* 文件拥有者的User ID
* 文件的Group ID
* 文件的读、写、执行权限
* 文件的时间戳,共有三个:
ctime指inode上一次变动的时间,
mtime指文件内容上一次变动的时间,
atime指文件上一次打开的时间。
* 链接数,即有多少文件名指向这个inode
* 文件数据block的位置
总之,除了文件名以外的所有文件信息,都存在inode之中。至于为什么没有文件名,下文会有详细解释


三、inode的大小

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

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

查看每个硬盘分区的inode总数和已经使用的数量,可以使用df命令;磁盘容量会与inode数成正比。

由于每个文件都必须有一个inode,因此有可能发生inode已经用光,但是硬盘还未存满的情况。这时,就无法在硬盘上创建新文件。会报磁盘空间已满的错误 No space left on device

四、inode号码

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

这里值得重复一遍,Unix/linux系统内部不使用文件名,而使用inode号码来识别文件。对于系统来说,文件名只是inode号码便于识别的别称或者绰号。

表面上,用户通过文件名,打开文件。实际上,系统内部这个过程分成三步:首先,系统找到这个文件名对应的inode号码;其次,通过inode号码,获取inode信息;最后,根据inode信息,找到文件数据所在的block,读出数据。

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

ls -il .bashrc
五、inode的特殊作用

由于inode号码与文件名分离,这种机制导致了一些Unix/Linux系统特有的现象。

1. 有时,文件名包含特殊字符,无法正常删除。这时,直接删除inode节点,就能起到删除文件的作用。

2. 移动文件或重命名文件,只是改变文件名,不影响inode号码。

3. 打开一个文件以后,系统就以inode号码来识别这个文件,不再考虑文件名。因此,通常来说,系统无法从inode号码得知文件名。

还有一点使得软件更新变得简单,可以在不关闭软件的情况下进行更新,不需要重启。因为系统通过inode号码,识别运行中的文件,不通过文件名。更新的时候,新版文件以同样的文件名,生成一个新的inode,不会影响到运行中的文件。等到下一次运行这个软件的时候,文件名就自动指向新版文件,旧版文件的inode则被回收。

六、innode 分区完后,可以增加码?

答:不可以。inode总数是在格式化时已经固定了的。
可以在格式化的时候指定大小
mkfs.ext4 -l 500000000000 /dev/sda1 

本文重点
如何解决inode爆满问题?
一般inode爆满情况就较为严重了,程序运维会有问题,会报磁盘无空间 No space left on device。所以做好监控非常重要。
线上服务器inode爆满但是磁盘空间还有很大是什么原因呢?其实就是小文件太多了,占用了所在磁盘的所有元数据空间,解决方案就是删除这么小文件或者mv 掉这些小文件
如何排查哪个目录占用inode多少了 可以用 df -i
如果删除 直接用 rm -rf xxx 基本是行不通的 会报 Argument list too long 问题,就是要删除的文件太多了。

通常会用
find . -ctime +180 -name “*” | xargs -i rm -rf {}

大概解释一下这个命令,删除当前目录下 180天前所有数据,如果还有 Argument list too long问题,就把时间适当调前一些,比如240天前 -ctime +240。这里按个人遇到的实际情况来定时间,一定要做好确认,避免误删除

inode爆满问题不好避免,所以在日常运维监控中强调磁盘的inode监控与磁盘空间的监控同等重要的事情.

 

1、DF命令干啥的?
df用来检查linux服务器的文件系统的磁盘空间占用情况。可以利用df来获取硬盘被占用了多少空间,剩多少空间。

功能:

显示指定文件的可用空间。如果没有文件名被指定,则所有当前被挂载的文件系统的可用空间将被显示。
默认情况下,磁盘空间将以1KB为单位进行显示,除非环境变量POSIXLY_CORRECT被指定,那样将以512字节为单位显示。
2、常用选项
-a –all,显示全部文件系统列表
h 方便阅读的形式来显示结果
-B 指定分区块大小
l 只显示本地文件系统
-i –inodes 列出 inode 资讯,不列出已使用 block
-T 显示系统文件类型
-P 输出格式为POSIX
-t<文件系统类型>只显示指定类型文件系统的磁盘信息,可以多次使用这个选项来包含更多的文件系统类型
-x<文件系统类型>不显示指定类型文件系统的磁盘信息,可以多次使用这个选项来包含更多的文件系统类型
1
2
3、实例
df ##显示所有挂载的文件系统的可用空间
1

tmpfs 是一个不存在于实体硬盘上、而是驻在记忆里的特殊文件系统。其中一个副作用就是当你失去电源(或重就开机)时,tmpfs 上的一切内容都会消失。tmpfs 驻守在内存里,它的速度极快。它的寻觅时间与驻守在硬盘上的一般文件系统根本不能相比。

df -a ###显示全部文件系统占用空间
1


df -T ###显示文件类型
1


df -h ##以方便阅读的方式显示
1

df -i #“-i”选项展示inode使用情况。在Linux中,inode是用来存储特定文件的元数据的一种数据结构,在创建一个文件系统时,inode的预先定义数量将被分配。这意味着,一个文件系统可能耗尽空间不只是因为大文件用完了所有可用空间,也可能是因为很多小文件用完了所有可能的inode。


4、列信息解析


Filesystem:代表文件系统对应的设备文件的路径名
1K-blocks:给出分区包含的数据块(1024字节)的数目
Used/Available:分别是已用和可用的数据块数目(第三四列数目之和不等于第二列,这是因为每个分区都留了少量空间供管理员使用;即使遇到管理员空间已满的情况下,管理员仍能登陆和留有解决问题所需的)
Use%:普通用户空间使用的百分比
Mounted on:文件系统挂载点

Inodes:节点容量
IUsed:已使用节点
IFree:未使用节点
IUse%:已使用所占百分比
inode包含的信息:文件的字节数,拥有者id,组id,权限,改动时间,链接数,数据block的位置。相反是不表示文件大小。

5、Df -i 和df -h显示使用率100%
在df -h 和df -i 显示使用率100%,基本解决方法都是删除文件。

df -h 是去删除比较大无用的文件-----------大文件占用大量的磁盘容量。

df -i 则去删除数量过多的小文件-----------过多的文件占用了大量的inode号。

posted @ 2024-06-04 10:44  人生苦短,知足常乐!  阅读(49)  评论(0编辑  收藏  举报