Linux df -h 显示磁盘空间满,但实际未占用满——问题分析

时间:2021-12-14 08:50:10

问题现象:

遇到一个问题,在系统上,告警提示磁盘空间不够,如下图所示:

Linux df -h 显示磁盘空间满,但实际未占用满——问题分析

问题分析:

1、首先使用 :du  -h  / --max-depth=1 命令查看各个目录的占用空间,试图找到占用较多空间的目录,

Linux df -h 显示磁盘空间满,但实际未占用满——问题分析

2、查看 inode 的使用率,怀疑 inode 不够导致此问题,

Linux df -h 显示磁盘空间满,但实际未占用满——问题分析

3、使用 lsof 检查,怀疑是不是有可能文件已被删除,但是进程还存活的场景,

Linux df -h 显示磁盘空间满,但实际未占用满——问题分析

Linux 里的文件被删除后,空间没有被释放是因为在 Linux 系统中,通过 rm 或者文件管理器删除文件将会从文件系统的目录结构上解除链接 (unlink) 。

然而如果文件是被打开的(有一个进程正在使用),那么进程将仍然可以读取该文件,磁盘空间也一直被占用。

装态为 deleted 为标记被删除,其实该文件并没有从磁盘中删除,类似windows下的回收站状态。

4、如果mount目录下原来是有文件存在的,那么该目录被 mount 之后这些文件就会被隐藏,不属于该文件系统,使用du命令是看不到的,

解决方法,

1、卸载挂载点:

Linux df -h 显示磁盘空间满,但实际未占用满——问题分析

2、重新将磁盘挂载到新的空目录

#mkdir  /opt/videos

#mount  /dev/sda1  /opt/videos

#mount  -a