在linux系统上,告警提示磁盘空间不够,如图所示
df -h
首先使用 sudo du / -h --max-depth=1 命令查看各个目录的占用空间,试图找到占用较多空间的目录
但是从结果显示来看并没有占用大空间的磁盘,于是乎继续分析。
查看 inode 的使用率,怀疑 inode 不够导致此问题
df -i
通过 df -i 命令查看后发现 inode 使用率也正常的,只能进一步分析。
使用 lsof 检查,怀疑是不是有可能文件已被删除,但是进程还存活的场景
sudo lsof |grep delete
Linux 里的文件被删除后,空间没有被释放是因为在 Linux 系统中,通过 rm 或者文件管理器删除文件将会从文件系统的目录结构上解除链接 (unlink) 。然而如果文件是被打开的(有一个进程正在使用),那么进程将仍然可以读取该文件,磁盘空间也一直被占用。装态为 deleted 为标记被删除,其实该文件并没有从磁盘中删除,类似windows下的回收站状态。
即使将如上所示的进程全部杀掉,发现空间占用仍是 100%,此时头大呀。。
突然回想起,是不是由于挂载盘导致的,
如果mount目录下原来是有文件存在的,那么该目录被 mount 之后这些文件就会被隐藏,不属于该文件系统,使用du命令是看不到的。
卸载挂载盘
df -h
查看卸载之后挂载盘大小
果然发现占用了磁盘空间。
将 videos 目录下的文件删除或拷贝到其他目录,并重新挂载
由此问题得到解决。
问题总结
在挂载目录时,要确认挂载的目录是否有文件,如果有文件那么挂载之后这些文件就会隐藏,此时使用 du 命令是看不到这些文件的。