使用du与df命令查看磁盘容量不一致

使用du与df命令查看磁盘容量不一致

 

问题描述

在Linux系统的ECS实例中,执行du与df命令查看磁盘容量,出现不一致的现象。

  • 问题1:执行df -h查看文件系统的使用率,可以看到/dev/xvdb1磁盘占用了约27G,挂载目录为/opt

    进入到/opt目录执行du -sh,显示空间总占用量约2.4G,即df与du命令查看到的结果不一致。

    使用du与df命令查看磁盘容量不一致_第1张图片

  • 问题2:通过df -h命令查看磁盘使用情况显示的是负值,如下图所示。

  • 问题3:执行du和df命令显示的容量不一致,df比du命令显示的数据大很多。

  • 问题4:使用df命令查询磁盘占用率很高,但是用du命令统计目录时却发现很低,且查不到已删除的句柄文件。

    使用du与df命令查看磁盘容量不一致_第2张图片

  • 问题5:当前系统存在数据盘挂载点。使用df命令查看系统盘占用容量已满,但是在根目录下使用du命令统计各文件总容量,合计并达不到总容量。

问题原因

  • 问题1的原因是用户删除了大量的文件后,du命令就不会在文件系统目录中统计这些文件。如果此时还在运行中的进程持有这个已经被删除的文件句柄,那么这个文件就不会真正在磁盘中被删除,分区超级块中的信息也就不会更改,df命令仍会统计这个被删除的文件。 通过lsof命令查询处于deleted状态的文件,被删除的文件在系统中被标记为deleted。如果系统有大量deleted状态的文件,会导致du和df命令统计结果不一致。 可在opt目录下执行如下命令查看。

    lsof |grep deleted
    
  • 问题2的原因是Linux系统磁盘分区有保留区的概念,会给root或指定用户预留5%或更大的空间,当使用到这块保留区的空间时,fdisk命令的计算将会是负数。ext文件系统(包括 ext2、ext3、ext4)都会默认预留5%的磁盘空间,使用root用户维护系统或记录系统关键日志使用。

  • 问题3的原因是当用du -sh *命令来统计目录总容量时,如果该路径下包含隐藏文件,是不会包含在统计结果里的。

  • 问题4的原因是由于删除了大量小文件,导致inode释放出现问题。

  • 问题5的原因是由于数据盘挂载前该路径下就存在文件,挂载后用du无法查询到原路径文件。

解决方案

本文主要针对以上五种问题,提供以下解决方案。

  • 问题1的解决方法是根据lsof列出的进程号,终止相应进程或者重启相应的服务。也可以重启实例,重启实例系统会退出现有的进程,开机后重新加载过程中,会释放调用的deleted文件的句柄。

    提示:如果ECS实例正在运行业务进程,终止进程时请慎重操作。

  • 问题2的解决方法是通过rm命令删除磁盘中的大文件,释放预留空间的占用后,再通过df命令查询磁盘占用即可恢复正常。

  • 问题3的解决方法是执行du -ah命令即可在统计结果中包含隐藏文件。

  • 问题4的解决方法是执行fsck命令后即可恢复正常。

  • 问题5的解决方法是卸载数据盘后再次使用du命令查询即可查到数据。

适用于

  • 云服务器ECS

你可能感兴趣的:(安全相关)