Tomcat日志catalina.out文件过大的处理方法
原文地址:http://lcbk.net/tomcat/1396.html
我们知道一般企业使用Tomcat 作为Web端时,它产生的日志会越来越大,特别是catalina.out
这个日志文件,然而有些人使用rm -rf catalina.out
直接删除掉这个文件,所导致的结果就是空间没有得到释放反而越来越大;
今天老蔡发现Tomcat的日志所在的opt分区约占越满,上服务器查看发现磁盘使用空间为100多G,但用du查看实际使用空间不到30G。因此70多G空间是因为删除正在读的文件而导致文件被删除而空间没释放造成的。
用lsof查看如下面所示,见标红行。处理办法:
- [root@h3.web.mzone.mdc.139.com /]# /usr/sbin/lsof|grep deleted
- php 4223 apache 1w REG 253,0 306483577 22578341 /tmp/status.log (deleted)
- php 4223 apache 2w REG 253,0 306483577 22578341 /tmp/status.log (deleted)
- php 7136 root 3uW REG 253,0 0 7410877 /var/lib/php/session/sess_vi88skak23129mhai12md342m6 (deleted)
- memcacheq 11644 apache 0u CHR 136,1 3 /dev/pts/1 (deleted)
- memcacheq 11753 apache 0u CHR 136,1 3 /dev/pts/1 (deleted)
- php 13479 apache 1w REG 253,0 75514309287 1051783 /tmp/audit_priority.log (deleted)
- php 13479 apache 2w REG 253,0 75514309287 1051783 /tmp/audit_priority.log (deleted)
- php 23809 apache 1w REG 253,0 19613 22578349 /tmp/webdisk.log (deleted)
- php 23809 apache 2w REG 253,0 19613 22578349 /tmp/webdisk.log (deleted)
- php 24935 apache 1w REG 253,0 571 22578598 /tmp/audit_auto_memcached.log (deleted)
- php 24935 apache 2w REG 253,0 571 22578598 /tmp/audit_auto_memcached.log (deleted)
- memcacheq 26671 apache 0u CHR 136,0 2 /dev/pts/0 (deleted)
- memcacheq 26677 apache 0u CHR 136,0 2 /dev/pts/0 (deleted)
1.重启机器或者重启相关服务(http)。
2.删掉进程,具体为:
- php 13479 apache 1w REG 253,0 75514309287 1051783 /tmp/audit_priority.log (deleted
)
从 lsof的输出中,可以发现pid为13479 的进程持有着以文件描述号(fd)为 1打开的文件/tmp/audit_priority.log。在我们找到了这个文件之后可以通过结束进程的方式来释放被占用的空间:
- kill -9 13479
为了杜绝这个问题,老蔡建议大家可以写个自定义的脚本,对于删除正在写的文件一般用 cat /dev/null > file,而不是直接rm(直接rm会造成文件删除空间不释放的问题)。
转载请务必注明来自»老蔡博客» 作者:老蔡 » 链接:http://lcbk.net/tomcat/1396.html
如果一件事情你觉得难的完不成,你可以把它分为若干步,并不断寻找合适的方法。最后你发现你会是个超人。不要给自己找麻烦,但遇到麻烦绝不怕,更不要退缩。
电工查找电路不通点的最快方法是:分段诊断排除,快速定位。你有什么启示吗?
求知若饥,虚心若愚。
当你对一个事情掌控不足的时候,你需要做的就是“梳理”,并制定相应的规章制度,并使资源各司其职。