首页 » linux » 正文

索引节点(inode)用满导致mkdir: cannot create directory `xxx’: No space left on device解决方法!

索引节点(inode)用满导致mkdir: cannot create directory `xxx’: No space left on device解决方法!

今天在处理网站报502 bad gateway时发现无法生成php-cgi.sock到tmp导致的服务器上所有网站报502

df -h发现系统盘和数据盘都是没有满的,创建文件或者创建目录下载文件都是无法执行,创建时提示:mkdir: cannot create directory `xxx’: No space left on device

df -i 其中/dev/mapper/vg_have-lv_root 884208 884208 0 100% /索引节点 (inode)满了 如下图:

20170512115731

已经找出问题所在,那么下面开始处理这个问题。

读出/目录下文件最多的目录:

for i in /*; do echo $i; find $i |wc -l|sort -nr; done

/var /www目录文件数高达10W以上,其中/var目录80W,/www为数据盘

再次读出/var目录下文件最多的目录:

for i in /var/*; do echo $i; find $i |wc -l|sort -nr; done

以此类推的往下找,最后在clientmqueue目录中文件数最多,切换到clientmqueue下使用rm -rf *  结果返回-bash: /bin/rm: Argument list too long

换用命令find . -print|xargs rm  过了一段时间终于删除了所有文件 df -i 下图可以看到文件数在减少

20170512120613

不过这种方法只是治标不治本的方法。

为什么var/spool/clientmqueue会产生大量的文件呢,查资料是因为cron执行时会将相关结果以mail方式发送到执行用户的帐号,可是当sendmail 沒有启动 那么所有信件就会暂存在这个目录中,此时就会出现这种情况。

治本的方法是在cron 任务中的后面加上 > /dev/null 2>&1

本教程由铁网维原创出品 服务器运维官方网址http://www.tieww.com 欢迎大家多多关注本站 感谢大家的支持。



本文共 3 个回复

  • 匿名 2019/12/31 17:39

    🙂

发表评论