欢迎您光临自学哈网,只为分享网络知识教程,供大家学习参考!

「自学哈网」“df”和“du”显示的磁盘空间使用情况不一致是什么问题

作者 : 自学哈 本文共1826个字,预计阅读时间需要5分钟 2023-04-27 共119人阅读
也想出现在这里? 联系我们

“df”和“du”显示的磁盘空间使用情况不一致是什么问题

 

在Linux下查看磁盘空间使用情况,最常使用的就是du和df了。然而两者还是有很大区别的,有时候其输出结果甚至非常悬殊。

 

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> 容量 已用 可用 已用%% 挂载点

/dev/sda1 49G 1.8G 44G 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)停止模拟进程,再对比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命令,然后停止相关进程即可。

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

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

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

本站声明:
本站所有资源来源于网络,分享目的仅供大家学习和交流!如若本站内容侵犯了原著者的合法权益,可联系邮箱976157886@qq.com进行删除。
自学哈专注于免费提供最新的分享知识、网络教程、网络技术的资源分享平台,好资源不私藏,大家一起分享!

自学哈网 » 「自学哈网」“df”和“du”显示的磁盘空间使用情况不一致是什么问题
也想出现在这里? 联系我们
© 2022 Theme by - 自学哈网 & WordPress Theme. All rights reserved 浙ICP备2022016594号