时间:2021-05-19
发现问题
最近在工作发现了一个错误,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 系统各挂载硬盘空间大小
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
很多网站服务器在日常运维过程中很多运维人员之关心数据盘空间占用大小,往往也会忽略系统盘的大小。典型案例:/var/spool/clientmqueue/操作系统
实例如下:vim/var/spool/cron/root*****sleep10;/usr/bin/curlhttp://localhost/index.php
前言注意本文说的“海量”并不是指体积大,而是指数量,比如一个目录下有数百万个小文件。最近在优化服务器时发现postfix下的maildrop目录和clientm
通过命令可以观察到/var/lib/Docker目录很大,我的主机只有20G,这个目录占了18G;原因是devicemapper的空间设的太大,通过docker
深入解析Linux下MySQL数据库的备份与还原1.备份[root@localhost~]#cd/var/lib/mysql(进入到MySQL库目录,根据自己的