发现问题
最近在工作发现了一个错误,MySQL 报错 Exception Message:SQLSTATE[08004][1040]Too many connections,经查这次错误是硬盘空间满了导致的,于是找一些可以删除的文件腾出一些空间。
空间占用大的原因
发现 /var/spool/postfix/maildrop 这个目录占用了 6G 多的空间,网上找到一样的问题,原因是:
由于 Linux 在执行 cron 时,会将 cron 执行脚本中的 output 和 warning 信息,都会以邮件的形式发送 cron 所有者, 而由于客户环境中的 sendmail 和 postfix 没有正常运行,导致邮件发送不成功,全部小文件堆积在了 maildrop 目录下面,而且没有自动清理转换的机制,所以长达一年的时间,此目录已堆积了大量的文件。查看 man cron 的信息,可以知道会发送给 cron owner.
于是尝试删除这个目录下的内容,但是执行 rm -rf ./* 竟然提示参数列表过长,后来使用如下命令删除:
ls | xargs rm -f
通过管道的方式删除。
脚本重定向输出
所以注意在 crontab 脚本输出内容到日志,或者 /dev/null 2>&1,避免产生大量不必要的文件。
几个 Linux 查找文件和空间的命令
find . -type f -size +1000000k 查找大文件和目录
du -s * | sort -nr | head 显示前十个占用空间最大的文件或目录
du -sh * 遍历目录大小
df -hl 系统各挂载硬盘空间大小
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对呐喊教程的支持。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。