问题背景:对系统进行压力测试,莫名导致tomcat的catalina.out被写入48G日志,导致磁盘空间被占满,此时在tomcat运行中使用rm -rf 命令删除该文件
问题描述:删除后df -hT显示80g空间全部占用(
磁盘空间占满),du -sh显示只占用20g
解决过程:1.查看/目录挂载的设备是否正常,发现/挂载点额设备是正常的80g,排除挂载问题
2.使用lsof|grep delete命令查看正在使用的已删除的文件,发现存在多个这样的文件,kill掉进程,问题解决原因:
1.使用rm命令删除文件时,只有当该文件不存在任何link才会被删除。当有进程访问这个文件时,i_count会增加1,该线程只要没被关闭,文件的实际占用空间就不会释放2.du是根据文件名进行的空间统计,使用rm时该文件对系统来说已经不可见,所以不会统计这个文件。df则是磁盘实际占用的数量。
参考:http://blog.csdn.net/liudunxu123/article/details/19823721