索引节点(inode)爆满问题处理
关于磁盘空间中索引节点爆满的问题还是挺多的,借此跟大家分享几个情况:
情况一
- 在公司一台配置较低的Linux服务器(内存、硬盘比较小)的/data分区内创建文件时,系统提示磁盘空间不足,用df -h命令查看了一下磁盘使用情况,发现/data分区只使用了66%,还有12G的剩余空间,按理说不会出现这种问题。
- 后来用df -i查看了一下/data分区的索引节点(inode),发现已经用满(IUsed=100%),导致系统无法创建新目录和文件。
- [root@bastion-IDC ~]# df -i
- Filesystem Inodes IUsed IFree IUse% Mounted on
- .......
- .......
- /dev/mapper/VolGroup-lv_home
- 53452800 53452800 0 100% /data
- inode译成中文就是索引节点,每个存储设备(例如硬盘)或存储设备的分区被格式化为文件系统后,应该有两部份,一部份是inode,另一部份是Block,Block是用来存储数据用的。而inode呢,就是用来存储这些数据的信息,这些信息包括文件大小、属主、归属的用户组、读写权限等。inode为每个文件进行信息索引,所以就有了inode的数值。操作系统根据指令,能通过inode值最快的找到相对应的文件。
- 这台服务器的Block虽然还有剩余,但inode已经用满,因此在创建新目录或文件时,系统提示磁盘空间不足。
- 排查是由于/data/cache目录中存在数量非常多的小字节缓存文件,占用的Block不多,但是占用了大量的inode。
- 解决方案:
- 1)删除/data/cache目录中的部分文件,释放出/data分区的一部分inode,特别要留意那些spool出来的文件,这种文件一般会占用比较多的节点,因为比较小而且零碎,同时要多留意日志文件信息等
- 2)用软连接将空闲分区/opt中的newcache目录连接到/data/cache,使用/opt分区的inode来缓解/data分区inode不足的问题:
- # ln -s /opt/newcache /data/cache
- 3)更换服务器,用高配置的服务器替换低配置的服务器。
情况二
- 问题:使用"df -h"命令发现磁盘使用率没有占满,但是无法写入文件,提示"no space left on device"!
- 原因:磁盘的inode节点使用爆满了!("df -i"命令查看/var空间的inode爆满)。
- -------------------------------------------------------------------------------
- 可能原因1:
- crontab里面定时执行的句子里没有加 > /dev/null 2>&1,系统中cron执行的程序有输出内容,
- 输出内容会以邮件形式发给cron的用户,而sendmail没有启动所以就产生了很大零碎的文件:
- crontab的job有问题,造成/var/spool/clientmqueue中产生许多的零碎文件。
- 处理方法:
- 用"rm -rf *"会不能删除,并会有相应的提示,大意是参数太多。
- 正确方法:
- 在/var/spool/clientmqueue/下执行命令:
- # lsattr ./|awk -F"/" '{print $3}'|xargs -i rm -rf {}
- 表示用lsattr列出./下面的文件名的属性,用awk取出名字,然后rm -rf
- 还有一个比较靠谱的方法:
- # find /var/spool/clientmqueue/ -type f -exec rm {} \;
- 或者在/var/spool/clientmqueue/目录下
- # cd /var/spool/clientmqueue/
- # find ./ -exec rm {} \;
- 将crontab中没有定向输出的行都在最后加上"> /dev/null 2>&1",在删除的过程中操作。
- 或者先停止crontab,加上重定向。
- --------------------------------------------------------------------------------
- 可能原因2
- 可以看下日志文件是否太多,如果是日志文件占用大量的inodes可以临时释放清理下过期的日志。
- 也可以根据较大目录的文件占用情况,临时转移部分文件到占用磁盘较小的目录中。
其他总结
- ===================================================
- 当发现某个分区下的inode使用率过大时,需要找到该分区下的某些目录里有哪些文件可以清理。
- 查找某个目录下一个月或两个月之前的文件,然后删除
- # find . -type f -mtime +30 |wc -l
- # find . -type f -mtime +60 |wc -l
- # find . -type f -mtime +30 -exec rm -f {} \;
- # find . -type f -mtime +60 -exec rm -f {} \;
- 释放inode缓存
- # sync
- # echo 3 > /proc/sys/vm/drop_caches
- 再次检查下磁盘inode使用情况
- # df -i
- ===================================================
- 1)删除无用的临时文件,释放inode。比如/tmp下有很多临时文件
- # ls -lt /tmp | wc -l
- # find /tmp -type f -exec rm {} \;
- 如果使用rm *,有可能因为文件数量太多而出现Argument list too long错误
- ------------------------------------------------------------------------------------------
- 是在linux下,试图传太多参数给一个系统命令(ls *; cp *; rm *; cat *; etc..)时,就会出现 Argument list too long错误。
- 解决方法:使用find -exec 遍历,然后执行删除便可。
- # find /tmp -type f -exec rm {} \;
- ------------------------------------------------------------------------------------------
- 2)除了的临时文件外,0字节的文件也会占用inode,应该也释放。
- # find /home -type f -size 0 -exec rm {} \;
- 3)inode爆满,也可能是某些目录下存在大量的小文件导致。
- 大量小文件分布有两种可能:
- a)一是只有一个或少量目录下存在大量小文件,这种情况可以使用如下命令来找出这个异常目录:
- # find / -type d -size +10M
- 即找出大小大于10M的目录(目录大小越大,表示目录下的文件越多)。
- b)大量的小文件分布在大量的目录下,这时候上面的命令可能找不出异常的目录,需要以下命令:
- # cd /
- # find */ ! -type l | cut -d / -f 1 | uniq -c
- 此命令作用是找出目录下文件总数,可能需要执行多次,直到找出具体的目录。比如上面的命令找出了/data目录下存在大量的小文件,
- 但/data/目录还有很多目录,这时候我们还需要继续执行:
- # cd /data
- # find */ ! -type l | cut -d / -f 1 | uniq -c
- 直到找出具体的目录。
- 如果可以直接删除节点满的文件夹:
- # find . -type f -exec rm {} \;
- 还可以按照文件的inode节点删除文件
- # find . -inum 342137 -exec rm -i {} \;
索引节点(inode)爆满问题处理的更多相关文章
- 由索引节点(inode)爆满引发的问题
关于磁盘空间中索引节点爆满的问题还是挺多的,借此跟大家分享一下: 一.发现问题在公司一台配置较低的Linux服务器(内存.硬盘比较小)的/data分区内创建文件时,系统提示磁盘空间不足,用df -h命 ...
- linux No space left on device 由索引节点(inode)爆满引发500问题
inode是什么? 理解inode,要从文件储存说起. 文件储存在硬盘上,硬盘的最小存储单位叫做"扇区"(Sector).每个扇区储存512字节(相当于0.5KB). 操作系统读取 ...
- 查找大文件 & 索引节点(inode)爆满 解决办法
经常遇到磁盘满或者文件节点满的情况,整理如下 查找大文件 查找超过某个大小的文件, 如1G find . -type f -size +1G 查找文件大小的时候,现实文件属性 find . -type ...
- Centos 06 文件类型和扩展名&索引节点inode和存储块block
本节内容 1.文件类型 2.文件扩展名 3.索引节点inode和block块 首先需要申明一点, 1.在linux里面文件扩展名和文件类型是没有关系的 2.为了容易区分和兼容用户使用windows的习 ...
- Linux索引节点(Inode)用满导致空间不足
一.问题出现 在创建新目录和文件是提示“no space left on device”!按照以前的情况,很有可能是服务器空间又被塞满了,通过命令查看,发现还有剩余.再用df -i查看了一下/分区的索 ...
- Linux索引节点(Inode:no space for device)用满导致的一次故障
问题描写叙述 在storm測试环境集群上上nimbus和supervisor自己主动挂调.重新启动时显示no space for device,也不能创建,加入文件及文件夹,df -h查看 ilesy ...
- 索引节点inode详解
Inode(index node),索引节点.Linux系统中,分区要进行格式化,创建文件系统.在每个Linux存储设备或存储设备的分区(可以是硬盘,软盘,U盘等)被格式化为ext3文件系统后,一般分 ...
- 索引节点inode
在Linux的文件系统中,索引节点是文件的标识,并且这个值是唯一的,两个不同的文件的索引节点值是不同的,索引节点相同的文件它们的内容是相同的,仅仅文件名不同.修改两个索引节点值相同的文件中的一个文件, ...
- Linux--文件描述符、文件指针、索引节点
Linux -- 文件描述符 文件描述符 Fd 当进程打开文件或创建新文件时,内核会返回一个文件描述符(非负整数),用来指向被打开的文件,所有执行I/O操作的系统调用(read.write)都会通过文 ...
随机推荐
- 第七章 鼠标(CHECKER4)
/*--------------------------------------------- CHECKER4.C -- Mouse Hit-Test Demo Program No.4 (c) C ...
- ccf--20160403---路径解析
本题思路如下: 具体的细节如下:首先去掉字符串中重复出现的/,然后遇到..,就删除栈的最后一个元素,.忽略 下面是代码和题目: 问题描述 试题编号: 201604-3 试题名称: 路径解析 时间限制: ...
- CanalSharp.AspNetCore v0.0.4-支持输出到MongoDB
一.多样输出支持 CanalSharp.AspNetCore是一个基于CanalSharp的适用于ASP.NET Core的一个后台任务组件,它可以随着ASP.NET Core实例的启动而启动,目前采 ...
- <20190103>别傻了,一些 新的技术注定只适合新人
故障现象: 用vmware跑的虚拟机不兼容 某银行网银的U盾. 插入usb口后无法识别U盾, 解决过程: 1 更换2台各自不同电脑, 使用前置USB口, 后置USB口. 故障依旧. 2 使 ...
- File类_深度遍历文件夹_练习
遍历指定目录下的所有文件和文件夹 import java.io.File; public class FileTest { public static void main(String[] args) ...
- input框下拉综合搜索
静态页面 <form action="houtai.php" method="get"> ...
- 最小生成树(图论)--3366lg【模版】
题目描述 如题,给出一个无向图,求出最小生成树,如果该图不连通,则输出orz 输入输出格式 输入格式: 第一行包含两个整数N.M,表示该图共有N个结点和M条无向边.(N<=5000,M<= ...
- [转]qtcreator中常用快捷键总结
F1 查看帮助 F2 跳转到函数定义(和Ctrl+鼠标左键一样的效果) Shift+F2 声明和定义之间切换 F4 头文件和源文件之间切换 Ctrl+ 欢迎模式 Ctrl+ 编辑模式 Ctrl+ 调试 ...
- MATLAB——线性神经网络
这个函数默认使用最小二乘,所以不需要训练 % example5_1.m x=-:; y=*x-; % 直线方程为 randn(); % 设置种子,便于重复执行 y=y+randn(,length(y ...
- 乱入Linux界的我是如何学习的
欢迎来到建哥学Linux,咳!咳!咳!开个玩笑哈,我是一个IT男,IT界的入门选手,正在学习Linux. 在之前,一直想进军IT界,学习IT技术,但是苦于没有人指导,也不知道学什么,最开始我自己在网上 ...