df和du命令查看磁盘时结果不一致

df和du命令查看磁盘时结果不一致

更新时间:2019-07-08 12:58:37

免责声明:本文档可能包含第三方产品信息,该信息仅供参考。阿里云对第三方产品的性能、可靠性以及操作可能带来的潜在影响,不做任何暗示或其他形式的承诺。

 

问题描述

  1. 登录实例,执行如下命令,查看Linux实例文件系统的使用率,发现/dev/xvdb1磁盘占用约27G,挂载目录为/opt
    df -h
    系统显示类似如下。
  2. 切换到/opt目录,执行如下命令,发现占用空间为2.4G,即df和du命令查看的结果不一致。
    du -sh

 

问题原因

du命令对统计的文件逐个进行fstat系统调用,获取文件大小。它的数据是基于文件获取,可以跨多个分区操作。df命令使用statfs系统调用,直接读取分区的超级块信息获取分区使用情况。它的数据基于分区元数据,只能针对整个分区。

 

删除大量的文件后,du命令不会在文件系统目录中统计删除的文件。如果此时还有运行中的进程持有被删除文件的句柄,那么此文件就不会真正的在磁盘中被删除,分区超级块中的信息也就不会更改,df命令仍会统计被删除文件的信息。

 

解决方案

方法一

  1. 切换至/opt目录,执行如下命令,查询处于deleted状态的文件,被删除的文件在系统中被标记为deleted。如果系统中存在大量deleted状态的文件,会导致du和df命令统计结果不一致。
    lsof |grep deleted
  2. 参考lsof命令列出的PID,执行如下命令,使用kill命令结束相应进程,或者重启相应的服务。
    提示:如果ECS实例正在运行业务进程,kill命令会直接终止进程,请慎重操作。
    kill -9 [$PID]
    注:[$PID]为lsof命令列出的PID。

 

方法二

重启实例,系统会退出现有的进程,开机后重新加载服务,此过程中会释放调用的deleted文件的句柄。

 

适用于

  • 云服务器 ECS

 

如果您的问题仍未解决,您可以在阿里云社区免费咨询,或提交工单联系阿里云技术支持。