Linux:df与du查看磁盘占用空间数据不一致的原因及解决方法

目录

一、原因分析

二、解决方法

三、其它问题


使用du -sh 和df -h 查看某一个目录占用的磁盘空间,有时会发现结果相差非常大,下面我们对这个问题详细说明一下。

一、原因分析

导致出现这种情况的主要原因是一部分进程访问的文件被删除了。

首先,需要先了解一下rm删除文件的原理:

使用rm命令删除文件时,只有当该文件不存在任何link才会真正被删除,当有进程访问这个文件时,虽然通过命令查不到这个文件了,但这个文件的实际占用空间并没有被释放。

du和df的区别如下:

du:根据文件名进行的空间统计,使用rm时该文件对系统来说已经不可见,所以不会统计这个文件。

df:是磁盘实际占用的数量

二、解决方法

首先,查看已删除但是未释放空间的文件:

lsof | grep deleted

通过查询结果的前2列,可以看到访问这些文件进程名和进程编号

然后,重启这些进程,或kill掉这些进程,这些文件占用的磁盘空间就真正释放了。

三、其它问题

但也存在暂时不能停止这些进程的情况。比如,这些进程由于业务需要7*24不间断对外提供服务。

此时,如果磁盘空间已经满了,可以考虑先把这些文件清空

1、先查找出这些文件的句柄编号

ls -l /proc/<pid>/fd/* | grep <文件名>

2、使用句柄编号清空文件

echo > /proc/<pid>/fd/<FD_NUM>

FD_NUM为上一步查找出的文件句柄编号,一般为数字

以上只是临时解决方案,实际最终还是需要将进程重启一下。

参考文档

linux 查找被删除但是未被释放空间的文件并释放资源
Linux不杀进程清理 lsof中deleted 状态的文件

相关推荐
TH_114 分钟前
腾讯云-(3)-Linux宝塔面板使用
linux·云计算·腾讯云
虚伪的空想家35 分钟前
arm架构服务器使用kvm创建虚机报错,romfile “efi-virtio.rom“ is empty
linux·运维·服务器·javascript·arm开发·云原生·kvm
火车头-1101 小时前
【docker 部署nacos1.4.7】
运维·docker·容器
深藏bIue1 小时前
linux服务器mysql目录下的binlog文件删除
linux·服务器·mysql
虾..1 小时前
Linux 进程状态
linux·运维·服务器
测试者家园1 小时前
DevOps 到底改变了测试什么?
运维·自动化测试·软件测试·devops·持续测试·智能化测试·软件测试和开发
扛枪的书生2 小时前
Linux 通用软件包 AppImage 打包详解
linux
只想安静的写会代码2 小时前
网卡信息查询、配置、常见故障排查
linux·服务器·windows
jiayong232 小时前
多子系统架构下的Nginx部署策略与最佳实践
运维·nginx·系统架构
皮糖小王子3 小时前
Docker打开本地镜像
运维·docker·容器