Linux df 与 du 结果不一致的原因

发布时间 - 2026-01-26 00:00:00    点击率:
df显示已用空间远大于du统计总和,因df统计文件系统级块使用(含元数据、预留空间、未释放的已删除文件),而du仅统计有硬链接且未被删除的文件内容块。

df 显示已用空间远大于 du 统计总和

这是最常见现象,根本原因在于 df 读取的是文件系统级的块使用情况(含元数据、预留空间、未释放的已删除文件),而 du 只遍历当前目录下「有硬链接且未被删除」的文件内容块。两者统计口径不同,不是 bug,是设计使然。

典型诱因包括:

  • 进程仍在写入已被 rm 删除的文件(该文件的 inode 未被真正回收,du 找不到路径,但 df 仍计入占用)
  • 文件系统启用了 root 预留空间(默认 5%,df 把它算进“已用”,但普通用户 du 不可见)
  • 存在稀疏文件(du 按实际数据块计,df 按分配的逻辑大小或文件系统映射计)
  • 挂载了 overlayfs、aufs 等分层文件系统,上层删除操作不立即释放底层空间

如何定位被删除但仍被进程占用的文件

这类文件是导致 dfdu 差值突增的首要怀疑对象。关键是找到那些状态为 deleted 但仍有进程打开的文件描述符。

执行以下命令:

lsof +L1 | grep -E 'DEL|deleted'

或更精准地按挂载点过滤(例如排查 /var):

lsof +L1 /var 2>/dev/null | grep -v "No such process"

输出中会显示进程 PID、用户、文件路径(通常带 (deleted) 标记)。确认后可重启对应服务,或直接 kill 进程释放空间。

du 忽略某些目录导致统计偏小

du 默认不进入其他挂载点(如 /proc/sys/boot 若为独立分区),也不统计不可读目录(权限不足时静默跳过)。这会让结果看起来比 df 小很多,但其实

只是没扫全。

检查是否遗漏挂载点:

findmnt -D /

重新运行 du 时加参数确保覆盖:

  • du -x:强制不跨文件系统(默认行为,一般不用加)
  • du -x --exclude='/proc' --exclude='/sys' --exclude='/dev' /:显式排除虚拟文件系统(避免误统计)
  • sudo du -shx /* 2>/dev/null:逐根目录统计,2>/dev/null 屏蔽权限错误

注意:du 对软链接默认不跟随,若需统计目标文件,加 -L;但生产环境慎用,可能引发循环引用或跨挂载点误入。

ext4/xfs 预留空间与 df 的“已用”计算逻辑

以 ext4 为例,df 报告的 “Used” 包含 root 预留块(通常是总空间 5%),即使普通用户磁盘已满,root 仍能写入。这部分空间对 du 完全不可见,但会拉高 df 的已用比例。

查看预留比例:

tune2fs -l /dev/sda1 | grep "Reserved block count"

调整(仅限必要时,且需 unmount 或只读 remount):

tune2fs -m 1 /dev/sda1

xfs 无固定百分比预留,但有 mkfs.xfs -m rtextsize= 等元数据相关保留,且 xfs_info 输出中的 data 段会显示实际可用块数,df 与其一致,du 仍只算文件内容。

真正容易被忽略的是:哪怕你把预留调成 0,只要存在未清理的 deleted 文件、快照(LVM/btrfs)、或 journal 日志膨胀,dfdu 的差值依然存在——得回到 lsof +L1journalctl --disk-usage 这类具体工具去查。


# linux  # node  # 工具  # NULL  # 循环  # var  # 对象  # bug  # 文件系统  # 已用  # 的是  # 未被  # 这类  # 普通用户  # 这是  # 也不  # 找不到  # 拉高 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何在IIS中配置站点IP、端口及主机头?  php读取心率传感器数据怎么弄_php获取max30100的心率值【指南】  用yum安装MySQLdb模块的步骤方法  如何在腾讯云服务器快速搭建个人网站?  Laravel如何使用.env文件管理环境变量?(最佳实践)  黑客如何通过漏洞一步步攻陷网站服务器?  Laravel怎么解决跨域问题_Laravel配置CORS跨域访问  Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  Swift中switch语句区间和元组模式匹配  Python进程池调度策略_任务分发说明【指导】  Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】  如何在阿里云香港服务器快速搭建网站?  Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置  jQuery中的100个技巧汇总  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  三星网站视频制作教程下载,三星w23网页如何全屏?  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  利用vue写todolist单页应用  黑客如何利用漏洞与弱口令入侵网站服务器?  详解Android中Activity的四大启动模式实验简述  公司网站制作价格怎么算,公司办个官网需要多少钱?  Laravel如何处理文件下载请求?(Response示例)  微信推文制作网站有哪些,怎么做微信推文,急?  Bootstrap CSS布局之列表  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  如何正确选择百度移动适配建站域名?  米侠浏览器网页图片不显示怎么办 米侠图片加载修复  千库网官网入口推荐 千库网设计创意平台入口  如何用PHP快速搭建CMS系统?  Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全  详解jQuery中基本的动画方法  如何在宝塔面板中创建新站点?  如何在阿里云虚拟服务器快速搭建网站?  大连 网站制作,大连天途有线官网?  Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  深圳网站制作的公司有哪些,dido官方网站?  Laravel如何实现密码重置功能_Laravel密码找回与重置流程  如何用y主机助手快速搭建网站?  Laravel如何实现API速率限制?(Rate Limiting教程)  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  js实现获取鼠标当前的位置  Laravel如何安装Breeze扩展包_Laravel用户注册登录功能快速实现【流程】  Microsoft Edge如何解决网页加载问题 Edge浏览器加载问题修复  EditPlus 正则表达式 实战(3)