关于磁盘空间中索引节点爆满的问题还是挺多的,借此跟大家分享几个情况:

情况一

  1. 在公司一台配置较低的Linux服务器(内存、硬盘比较小)的/data分区内创建文件时,系统提示磁盘空间不足,用df -h命令查看了一下磁盘使用情况,发现/data分区只使用了66%,还有12G的剩余空间,按理说不会出现这种问题。
  2.  
  3. 后来用df -i查看了一下/data分区的索引节点(inode),发现已经用满(IUsed=100%),导致系统无法创建新目录和文件。
  4. [root@bastion-IDC ~]# df -i
  5. Filesystem Inodes IUsed IFree IUse% Mounted on
  6. .......
  7. .......
  8. /dev/mapper/VolGroup-lv_home
  9. 53452800 53452800 0 100% /data
  10.  
  11. inode译成中文就是索引节点,每个存储设备(例如硬盘)或存储设备的分区被格式化为文件系统后,应该有两部份,一部份是inode,另一部份是BlockBlock是用来存储数据用的。而inode呢,就是用来存储这些数据的信息,这些信息包括文件大小、属主、归属的用户组、读写权限等。inode为每个文件进行信息索引,所以就有了inode的数值。操作系统根据指令,能通过inode值最快的找到相对应的文件。
  12.  
  13. 这台服务器的Block虽然还有剩余,但inode已经用满,因此在创建新目录或文件时,系统提示磁盘空间不足。
  14.  
  15. 排查是由于/data/cache目录中存在数量非常多的小字节缓存文件,占用的Block不多,但是占用了大量的inode
  16.  
  17. 解决方案:
  18. 1)删除/data/cache目录中的部分文件,释放出/data分区的一部分inode,特别要留意那些spool出来的文件,这种文件一般会占用比较多的节点,因为比较小而且零碎,同时要多留意日志文件信息等
  19.  
  20. 2)用软连接将空闲分区/opt中的newcache目录连接到/data/cache,使用/opt分区的inode来缓解/data分区inode不足的问题:
  21. # ln -s /opt/newcache /data/cache
  22.  
  23. 3)更换服务器,用高配置的服务器替换低配置的服务器。

情况二

  1. 问题:使用"df -h"命令发现磁盘使用率没有占满,但是无法写入文件,提示"no space left on device"!
  2. 原因:磁盘的inode节点使用爆满了!("df -i"命令查看/var空间的inode爆满)。
  3.  
  4. -------------------------------------------------------------------------------
  5. 可能原因1
  6. crontab里面定时执行的句子里没有加 > /dev/null 2>&1,系统中cron执行的程序有输出内容,
  7. 输出内容会以邮件形式发给cron的用户,而sendmail没有启动所以就产生了很大零碎的文件:
  8. crontabjob有问题,造成/var/spool/clientmqueue中产生许多的零碎文件。
  9.  
  10. 处理方法:
  11. "rm -rf *"会不能删除,并会有相应的提示,大意是参数太多。
  12.  
  13. 正确方法:
  14. 在/var/spool/clientmqueue/下执行命令:
  15. # lsattr ./|awk -F"/" '{print $3}'|xargs -i rm -rf {}
  16.  
  17. 表示用lsattr列出./下面的文件名的属性,用awk取出名字,然后rm -rf
  18.  
  19. 还有一个比较靠谱的方法:
  20. # find /var/spool/clientmqueue/ -type f -exec rm {} \;
  21.  
  22. 或者在/var/spool/clientmqueue/目录下
  23. # cd /var/spool/clientmqueue/
  24. # find ./ -exec rm {} \;
  25.  
  26. crontab中没有定向输出的行都在最后加上"> /dev/null 2>&1",在删除的过程中操作。
  27. 或者先停止crontab,加上重定向。
  28. --------------------------------------------------------------------------------
  29. 可能原因2
  30. 可以看下日志文件是否太多,如果是日志文件占用大量的inodes可以临时释放清理下过期的日志。
  31. 也可以根据较大目录的文件占用情况,临时转移部分文件到占用磁盘较小的目录中。

其他总结

  1. ===================================================
  2. 当发现某个分区下的inode使用率过大时,需要找到该分区下的某些目录里有哪些文件可以清理。
  3. 查找某个目录下一个月或两个月之前的文件,然后删除
  4. # find . -type f -mtime +30 |wc -l
  5. # find . -type f -mtime +60 |wc -l
  6. # find . -type f -mtime +30 -exec rm -f {} \;
  7. # find . -type f -mtime +60 -exec rm -f {} \;
  8.  
  9. 释放inode缓存
  10. # sync
  11. # echo 3 > /proc/sys/vm/drop_caches
  12.  
  13. 再次检查下磁盘inode使用情况
  14. # df -i
  15. ===================================================
  16.  
  17. 1)删除无用的临时文件,释放inode。比如/tmp下有很多临时文件
  18. # ls -lt /tmp | wc -l
  19. # find /tmp -type f -exec rm {} \;
  20.  
  21. 如果使用rm *,有可能因为文件数量太多而出现Argument list too long错误
  22. ------------------------------------------------------------------------------------------
  23. 是在linux下,试图传太多参数给一个系统命令(ls *; cp *; rm *; cat *; etc..)时,就会出现 Argument list too long错误。
  24.  
  25. 解决方法:使用find -exec 遍历,然后执行删除便可。
  26. # find /tmp -type f -exec rm {} \;
  27. ------------------------------------------------------------------------------------------
  28.  
  29. 2)除了的临时文件外,0字节的文件也会占用inode,应该也释放。
  30. # find /home -type f -size 0 -exec rm {} \;
  31.  
  32. 3inode爆满,也可能是某些目录下存在大量的小文件导致。
  33. 大量小文件分布有两种可能:
  34. a)一是只有一个或少量目录下存在大量小文件,这种情况可以使用如下命令来找出这个异常目录:
  35. # find / -type d -size +10M
  36. 即找出大小大于10M的目录(目录大小越大,表示目录下的文件越多)。
  37.  
  38. b)大量的小文件分布在大量的目录下,这时候上面的命令可能找不出异常的目录,需要以下命令:
  39. # cd /
  40. # find */ ! -type l | cut -d / -f 1 | uniq -c
  41. 此命令作用是找出目录下文件总数,可能需要执行多次,直到找出具体的目录。比如上面的命令找出了/data目录下存在大量的小文件,
  42. 但/data/目录还有很多目录,这时候我们还需要继续执行:
  43. # cd /data
  44. # find */ ! -type l | cut -d / -f 1 | uniq -c
  45. 直到找出具体的目录。
  46.  
  47. 如果可以直接删除节点满的文件夹:
  48. # find . -type f -exec rm {} \;
  49.  
  50. 还可以按照文件的inode节点删除文件
  51. # find . -inum 342137 -exec rm -i {} \;

索引节点(inode)爆满问题处理的更多相关文章

  1. 由索引节点(inode)爆满引发的问题

    关于磁盘空间中索引节点爆满的问题还是挺多的,借此跟大家分享一下: 一.发现问题在公司一台配置较低的Linux服务器(内存.硬盘比较小)的/data分区内创建文件时,系统提示磁盘空间不足,用df -h命 ...

  2. linux No space left on device 由索引节点(inode)爆满引发500问题

    inode是什么? 理解inode,要从文件储存说起. 文件储存在硬盘上,硬盘的最小存储单位叫做"扇区"(Sector).每个扇区储存512字节(相当于0.5KB). 操作系统读取 ...

  3. 查找大文件 & 索引节点(inode)爆满 解决办法

    经常遇到磁盘满或者文件节点满的情况,整理如下 查找大文件 查找超过某个大小的文件, 如1G find . -type f -size +1G 查找文件大小的时候,现实文件属性 find . -type ...

  4. Centos 06 文件类型和扩展名&索引节点inode和存储块block

    本节内容 1.文件类型 2.文件扩展名 3.索引节点inode和block块 首先需要申明一点, 1.在linux里面文件扩展名和文件类型是没有关系的 2.为了容易区分和兼容用户使用windows的习 ...

  5. Linux索引节点(Inode)用满导致空间不足

    一.问题出现 在创建新目录和文件是提示“no space left on device”!按照以前的情况,很有可能是服务器空间又被塞满了,通过命令查看,发现还有剩余.再用df -i查看了一下/分区的索 ...

  6. Linux索引节点(Inode:no space for device)用满导致的一次故障

    问题描写叙述 在storm測试环境集群上上nimbus和supervisor自己主动挂调.重新启动时显示no space for device,也不能创建,加入文件及文件夹,df -h查看 ilesy ...

  7. 索引节点inode详解

    Inode(index node),索引节点.Linux系统中,分区要进行格式化,创建文件系统.在每个Linux存储设备或存储设备的分区(可以是硬盘,软盘,U盘等)被格式化为ext3文件系统后,一般分 ...

  8. 索引节点inode

    在Linux的文件系统中,索引节点是文件的标识,并且这个值是唯一的,两个不同的文件的索引节点值是不同的,索引节点相同的文件它们的内容是相同的,仅仅文件名不同.修改两个索引节点值相同的文件中的一个文件, ...

  9. Linux--文件描述符、文件指针、索引节点

    Linux -- 文件描述符 文件描述符 Fd 当进程打开文件或创建新文件时,内核会返回一个文件描述符(非负整数),用来指向被打开的文件,所有执行I/O操作的系统调用(read.write)都会通过文 ...

随机推荐

  1. 第七章 鼠标(CHECKER4)

    /*--------------------------------------------- CHECKER4.C -- Mouse Hit-Test Demo Program No.4 (c) C ...

  2. ccf--20160403---路径解析

    本题思路如下: 具体的细节如下:首先去掉字符串中重复出现的/,然后遇到..,就删除栈的最后一个元素,.忽略 下面是代码和题目: 问题描述 试题编号: 201604-3 试题名称: 路径解析 时间限制: ...

  3. CanalSharp.AspNetCore v0.0.4-支持输出到MongoDB

    一.多样输出支持 CanalSharp.AspNetCore是一个基于CanalSharp的适用于ASP.NET Core的一个后台任务组件,它可以随着ASP.NET Core实例的启动而启动,目前采 ...

  4. <20190103>别傻了,一些 新的技术注定只适合新人

    故障现象:    用vmware跑的虚拟机不兼容 某银行网银的U盾. 插入usb口后无法识别U盾, 解决过程: 1  更换2台各自不同电脑, 使用前置USB口, 后置USB口.  故障依旧. 2  使 ...

  5. File类_深度遍历文件夹_练习

    遍历指定目录下的所有文件和文件夹 import java.io.File; public class FileTest { public static void main(String[] args) ...

  6. input框下拉综合搜索

    静态页面 <form action="houtai.php" method="get">                               ...

  7. 最小生成树(图论)--3366lg【模版】

    题目描述 如题,给出一个无向图,求出最小生成树,如果该图不连通,则输出orz 输入输出格式 输入格式: 第一行包含两个整数N.M,表示该图共有N个结点和M条无向边.(N<=5000,M<= ...

  8. [转]qtcreator中常用快捷键总结

    F1 查看帮助 F2 跳转到函数定义(和Ctrl+鼠标左键一样的效果) Shift+F2 声明和定义之间切换 F4 头文件和源文件之间切换 Ctrl+ 欢迎模式 Ctrl+ 编辑模式 Ctrl+ 调试 ...

  9. MATLAB——线性神经网络

     这个函数默认使用最小二乘,所以不需要训练 % example5_1.m x=-:; y=*x-; % 直线方程为 randn(); % 设置种子,便于重复执行 y=y+randn(,length(y ...

  10. 乱入Linux界的我是如何学习的

    欢迎来到建哥学Linux,咳!咳!咳!开个玩笑哈,我是一个IT男,IT界的入门选手,正在学习Linux. 在之前,一直想进军IT界,学习IT技术,但是苦于没有人指导,也不知道学什么,最开始我自己在网上 ...