df和du显示的磁盘空间使用情况不一致的原因及处理(文件删除后磁盘空间不释放)

1. 如何记忆这两个命令

du-Disk Usage

df-Disk Free

2. df 和du 的工作原理

2.1 du的工作原理

du命令会对待统计文件逐个调用fstat这个系统调用,获取文件大小。它的数据是基于文件获取的,所以有很大的灵活性,不一定非要针对一个分区,可以跨越多个分区操作。如果针对的目录中文件很多,du速度就会很慢了。

2.2 df的工作原理

df命令使用的事statfs这个系统调用,直接读取分区的超级块信息获取分区使用情况。它的数据是基于分区元数据的,所以只能针对整个分区。由于df直接读取超级块,所以运行速度不受文件多少影响。

3 du和df不一致情况模拟

常见的df和du不一致情况就是文件删除的问题。当一个文件被删除后,在文件系统 目录中已经不可见了,所以du就不会再统计它了。然而如果此时还有运行的进程持有这个已经被删除了的文件的句柄,那么这个文件就不会真正在磁盘中被删除, 分区超级块中的信息也就不会更改。这样df仍旧会统计这个被删除了的文件。

(1)当前分区sda1的使用情况

[root@CentOS192 testdu]# df -h /dev/sda1
文件系统      容量  已用  可用 已用%% 挂载点
/dev/sda1              49G  776M  45G  2% /var

(2)新建一个1GB的大文件

[root@centos192 var]# dd if=/dev/zero of=myfile.iso bs=1024k count=1000
记录了1000+0 的读入
记录了1000+0 的写出
1048576000字节(1.0 GB)已复制,24.0954 秒,43.5 MB/秒

(3)此时的分区sda1使用情况

df结果:

[root@centos192 var]# df -h /dev/sda1
文件系统<span style="white-space: pre;"> </span> &nbsp; &nbsp; &nbsp;容量 &nbsp;已用 &nbsp;可用 已用%% 挂载点
/dev/sda1 &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;49G &nbsp;1.8G &nbsp; 44G &nbsp; 4% /var

du结果:

[root@centos192 var]# du -sh /var/
1.6G /var/

此时两者结果基本相同。

(4)模拟一个进程打开这个大文件,然后删除这个大文件

[root@centos192 var]# tail -f myfile.iso &
[1] 23277
[root@centos192 var]# rm -f myfile.iso

(5)此时,再对比du和df的结果
 
首先确认有进程持有myfile.iso句柄。

[root@centos192 var]# lsof | grep myfile.iso
tail     
23955      root    3r      REG                8,1 1048576000      7999 /var/myfile.iso (deleted)

[root@centos192 var]# du -sh /var/
596M /var/
[root@centos192 var]# df -h /dev/sda1
文件系统      容量  已用  可用 已用%% 挂载点
/dev/sda1              49G  1.8G  44G  4% /var

可以看出,df结果没有变化,而du则不再统计被删除了的文件myfile.iso。

(6)停止模拟进程(kill -9 23955),再对比du和df结果

首先确认没有进程持有myfile.iso句柄。

[root@centos192 var]# lsof | grep myfile.iso
[root@centos192 var]#

[root@centos192 var]# du -sh /var/; df -h /dev/sda1
596M /var/
文件系统      容量  已用  可用 已用%% 挂载点
/dev/sda1              49G  776M  45G  2% /var

此时,myfile.iso已经没有进程占有它了,也就从磁盘上删除了,分区的超级块信息已经更改,df也就显示正常了。

4 工作中需要注意的地方

(1)当出现du和df差距很大的情况时,考虑是否是有删除文件未完成造成的,方法是lsof命令,然后停止相关进程即可(这一步需要相当小心,因为这个进程很可能是非常重要的应用起动的进程,因此,在kill -9 ${进程号} 前一定要确认该进程是否可直接停掉)。

(2)可以使用清空文件的方式来代替删除文件,方式是:echo > myfile.iso。

(3)对于经常发生删除问题的日志文件,以改名、清空、删除的顺序操作。

(4)除了rm外,有些命令会间接的删除文件,如gzip命令完成后会删除原来的文件,为了避免删除问题,压缩前先确认没有进程打开该文件。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这三个命令是用来查看磁盘空间的,但是它们的输出结果有一些不同,这就导致了磁盘空间显示一致的问题。 首先,du命令是用来查看目录或文件所占用的磁盘空间的,它的输出结果是以字节为单位的。而df命令则是用来查看磁盘分区的使用情况的,它的输出结果是以块为单位的。 其次,du命令df命令的参数也不同。du命令后面跟的是目录或文件名,而df命令后面跟的是磁盘分区的挂载点。 最后,du命令df命令的输出结果格式也不同。du命令的输出结果是一个目录或文件所占用的磁盘空间,它的单位可以是字节、千字节、兆字节等。而df命令的输出结果则是磁盘分区的总容量、已用容量、可用容量和使用率,它的单位通常是千字节或兆字节。 所以,如果你使用du -sh命令来查看一个目录或文件所占用的磁盘空间,它的输出结果是以人类可读的格式显示的。而如果你使用df -h命令来查看磁盘分区的使用情况,它的输出结果也是以人类可读的格式显示的。但是,它们的单位不同,所以输出结果可能会有一些差异。此外,df命令还可以使用-a参数来显示所有文件系统的磁盘使用情况,包括那些没有挂载的文件系统,这也会导致输出结果与du命令不同。 综上所述,dudf命令的输出结果不同,使用的参数和单位也不同,因此会导致磁盘空间显示一致的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值