Linux df 与 du 显示结果不一致的根本原因

发布时间 - 2026-01-28 00:00:00    点击率:
df显示已用空间远大于du总和,主因是df统计文件系统级已分配块(含已

删未释文件、保留空间等),而du仅统计仍有硬链接的文件内容块。

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

这是最常见现象,根本原因在于 df 统计的是文件系统级的已分配块(包括被删除但未释放的文件、保留空间、元数据开销等),而 du 只遍历当前目录树下「仍被硬链接引用」的文件内容块。当进程仍在读写一个已被 rm 删除的文件时,该文件的磁盘块不会被 du 计入(路径已消失),但 df 仍将其算作“已用”。

  • 运行 lsof +L1 查看所有处于 unlink 状态但仍被进程打开的文件(即“幽灵文件”)
  • 确认后可重启对应进程,或直接 kill -HUP 其 PID 促使释放
  • du 默认不统计硬链接重复计数,而 df 不关心链接关系,只看块是否被标记为已用

du 忽略挂载点子目录导致统计偏小

如果目标路径下存在其他文件系统挂载点(如 /mnt/data 是独立挂载的 ext4 分区),du 默认不会递归进入这些挂载点——它把它们当作普通目录,但实际内容在另一套 inode 和块管理中。此时 du 结果必然小于 df 报告的根分区使用量。

  • -x 参数让 du 跨文件系统时跳过(默认行为),加 --all 无帮助,关键是用 -x 的反向逻辑:去掉它才能跨挂载点统计
  • 更稳妥的做法是分别对每个挂载点单独运行 du -sh /path/to/mount
  • findmntmount | grep " / " 快速识别嵌套挂载

ext4 的 reserved blocks 和 df 的计算偏差

ext2/3/4 默认预留 5% 的块给 root 用户,防止系统因磁盘满而崩溃。这部分空间在 df 输出中计入“Available”,但不计入“Used”,却会影响总量计算逻辑;更重要的是,df 展示的 “Size” 是总块数减去 reserved,而 du 完全不感知 reserved 概念——它只管“哪些块正在被文件占用”。所以即使没有幽灵文件、也没有嵌套挂载,两者数值仍有固定偏差。

  • 查看预留比例:tune2fs -l /dev/sdXN | grep "Reserved block count"
  • 临时调低(仅限非系统分区):tune2fs -m 1 /dev/sdXN,设为 0 风险极高,不建议
  • 这个偏差通常只影响百分比精度,不影响判断是否真满

权限不足导致 du 漏统计部分目录

du 是用户态命令,遇到无读取权限的目录(如 /root、某些容器卷挂载点)会跳过,静默忽略,不报错也不提示。而 df 是内核接口直读 superblock,完全不受用户权限限制。结果就是 du 总和明显偏小,且找不到明显原因。

  • 2>/dev/null 会掩盖问题,调试时务必先去掉重定向,观察 stderr 输出
  • sudo du -sh / 可绕过权限限制,但要注意 sudo 下的环境变量和 PATH 可能影响某些脚本行为
  • 容器场景中,du 在宿主机执行可能无法访问容器内部挂载的 tmpfs 或 overlay2 层,需进容器 namespace 才准
差值本身不可怕,可怕的是把 du 当成磁盘真实占用证据,或者看到 df 显示 98% 就立刻 panic 却没查 lsof +L1 ——很多“磁盘满”的故障,其实只是日志文件被删没关进程。


# linux  # node  # ai  # 环境变量  # NULL  # count  # 递归  # 接口  # Namespace  # 的是  # 文件系统  # 已用  # 仍有  # 跳过  # 偏小  # 这是  # 也不  # 找不到 


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


相关推荐: Laravel项目怎么部署到Linux_Laravel Nginx配置详解  长沙企业网站制作哪家好,长沙水业集团官方网站?  百度输入法ai组件怎么删除 百度输入法ai组件移除工具  Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制  详解Android中Activity的四大启动模式实验简述  如何用AWS免费套餐快速搭建高效网站?  如何在云主机上快速搭建多站点网站?  ,交易猫的商品怎么发布到网站上去?  北京网站制作公司哪家好一点,北京租房网站有哪些?  Laravel如何配置任务调度?(Cron Job示例)  如何在阿里云ECS服务器部署织梦CMS网站?  Laravel如何实现密码重置功能_Laravel密码找回与重置流程  Laravel怎么实现一对多关联查询_Laravel Eloquent模型关系定义与预加载【实战】  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法  Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  如何在云主机快速搭建网站站点?  HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  Laravel如何处理CORS跨域请求?(配置示例)  简单实现Android验证码  Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】  Laravel如何实现用户注册和登录?(Auth脚手架指南)  Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲  小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像  做企业网站制作流程,企业网站制作基本流程有哪些?  Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转  Java类加载基本过程详细介绍  独立制作一个网站多少钱,建立网站需要花多少钱?  canvas 画布在主流浏览器中的尺寸限制详细介绍  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  如何快速完成中国万网建站详细流程?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  微信小程序 canvas开发实例及注意事项  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  js实现获取鼠标当前的位置  Laravel如何使用Sanctum进行API认证?(SPA实战)  Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用  Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置  微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】  香港服务器如何优化才能显著提升网站加载速度?