百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

使用 df 命令检查服务器磁盘满了,但用 du 命令发现实际小于磁盘容量

yuyutoo 2025-06-28 17:45 10 浏览 0 评论

在 Linux 系统中,管理员或开发者经常会遇到一个令人困惑的问题:使用 df 命令检查磁盘使用情况时,显示某个分区已经 100% 满,但使用 du 命令统计文件占用时,却发现实际占用的空间远小于磁盘容量。这种矛盾的现象往往让人摸不着头脑,磁盘空间到底去哪儿了?本文将提供详细的排查方法和解决方案,确保你能彻底搞懂这个问题!

df 和 du 命令的原理

要理解 dfdu 的矛盾,首先需要了解这两个命令的工作原理和它们之间的区别。

1. df 命令:查看文件系统的使用情况

dfdisk free)命令用于显示文件系统的磁盘使用情况,包括总空间、已用空间、可用空间等信息。它的输出基于文件系统的元数据**,反映的是整个文件系统的状态,而不仅仅是用户文件的内容。

常用命令:

  • o df -h: 以人性化方式(GB、MB 等单位)显示磁盘使用情况,便于阅读。
df -h

o df -i: 显示 inode 使用情况,检查 inode 是否耗尽。df -i

o df -T: 显示文件系统类型(如 ext4、xfs)。df -T

df 的核心特点是它依赖文件系统的元数据,因此某些特殊情况(如文件被删除但仍被进程占用)会导致 df 显示的空间占用与实际不符。

2. du 命令:统计目录或文件的实际占用

dudisk usage)命令用于统计指定目录或文件的实际磁盘占用,基于文件的实际大小进行计算。它会递归遍历目录,累加每个文件和子目录的占用空间。

常用命令:

  • o du -sh /path: 以人性化方式显示指定路径的总占用。
du -sh /var

o du -ah /path | sort -rh: 显示路径下所有文件和目录的占用,按大小排序。du -ah /var | sort -rh | head -n 10

o du -s --apparent-size /path: 显示文件的表观大小(不考虑稀疏文件或压缩)。du -s --apparent-size /var

o du --block-size=1 /path: 以字节为单位显示占用,精确到字节级。du --block-size=1 /var

du 的核心特点是它只统计文件内容的实际占用,不会考虑文件系统元数据或被删除但仍被占用的文件句柄。

3. df 和 du 的差异总结

`

  • o 数据来源df 基于文件系统元数据,du 基于文件内容。
  • o 统计范围df 反映整个文件系统的状态,du 只统计指定路径的文件。
  • o 特殊情况df 会包含被删除但未释放的文件、挂载点覆盖等情况,而 du 不会。

了解了 dfdu 的差异,我们可以开始分析 df 显示 100% 但 du 占用少的三种主要原因。

原因一:已删除但未释放的文件

这是 dfdu 结果不一致的最常见原因。当一个文件被删除(rm 命令),但仍有进程持有该文件的句柄时,文件的内容仍然占用磁盘空间,直到所有持有该句柄的进程结束。这种情况下:

  • o df:会显示文件占用空间,因为文件系统元数据中该空间仍被标记为已分配。
  • o du:不会统计已删除文件,因为 du 无法访问已删除文件的路径。

1.如何排查

使用 lsoffuser 命令可以找到仍在占用已删除文件的进程。

  • o 使用 lsof 检查打开的已删除文件
lsof | grep deleted

示例输出:

httpd   12345 apache  5u  REG  8,1  5242880  123456  /var/log/httpd/access.log (deleted)

输出显示进程 httpd(PID 12345)仍持有已删除的 /var/log/httpd/access.log 文件,占用 5242880 字节。

  • o 使用 lsof 检查特定文件系统的已删除文件
lsof /mount_point | grep deleted

例如:

lsof / | grep deleted
  • o 使用 fuser 检查文件系统占用
fuser -m /mount_point

示例输出:

/mount_point:  12345  67890

显示 PID 12345 和 67890 的进程正在使用该文件系统。

  • o 检查 /proc 目录下进程打开的文件
ls -l /proc/*/fd | grep deleted

示例输出:

lrwx------ 1 root root 64 Jun 24 10:00 /proc/12345/fd/5 -> /var/log/app.log (deleted)

2. 如何解决

找到占用已删除文件的进程后,可以通过以下方法释放空间:

  • o 重启相关进程
kill -HUP 12345

或:

systemctl restart service_name

例如:

systemctl restart httpd
  • o 杀死进程(谨慎操作):
kill -9 12345
  • o 清空文件内容(不中断进程):

如果不希望重启进程,可以清空文件内容以释放空间:

> /proc/12345/fd/5
  • o 预防措施o 定期清理日志文件(如使用 logrotate)。o 使用 truncate 命令定期截断大文件:
truncate -s 0 /var/log/large.log

原因二:挂载点覆盖

当一个新的文件系统被挂载到已有的挂载点上时,原挂载点下的文件会被“隐藏”,但它们仍然占用磁盘空间。这种情况下:

  • o df:显示的是新挂载点的使用情况,可能接近 100%。
  • o du:只统计新挂载点下的文件,无法访问被覆盖的旧文件。

1. 如何排查

  • o 检查挂载点

使用 mountfindmnt 命令查看当前挂载情况:

mount | grep /mount_point

或:

findmnt /mount_point

示例输出:

/dev/sdb1 /mnt ext4 rw,relatime 0 0
  • o 检查是否存在重复挂载
cat /proc/mounts | grep /mount_point

如果同一挂载点出现多次,说明可能存在覆盖。

  • o 检查隐藏文件

临时卸载挂载点,查看原始挂载点下的内容:

umount /mount_point
du -sh /mount_point

如果卸载后 du 显示大量占用,说明有隐藏文件。

2. 如何解决

  • o 卸载多余挂载点
umount /mount_point
  • o 清理隐藏文件

在卸载后,删除不需要的文件:

rm -rf /mount_point/unneeded_files
  • o 重新挂载

确保挂载到正确的路径:

mount /dev/sdb1 /mnt
  • o 预防措施o 在挂载前检查目标路径是否为空:
ls -a /mount_point
  • o 使用 findmnt 定期检查挂载点状态。

原因三:文件系统元数据问题

文件系统的元数据(如 inode、保留块、坏块等)也可能导致 df 显示磁盘满,但 du 占用少。常见情况包括:

  • o Inode 耗尽:文件系统 inode 数量不足,无法创建新文件。
  • o 保留块占用:文件系统为 root 用户保留了一定比例的空间。
  • o 坏块或文件系统损坏:导致空间被错误标记为已占用。

1. 如何排查

  • o 检查 inode 使用情况
df -i

如果 IUse% 显示 100%,说明 inode 已耗尽。

  • o 查找占用 inode 的小文件
find /path -type f -size -1M | wc -l

或:

for dir in $(find /path -type d); do echo "$(find $dir -type f | wc -l) $dir"; done | sort -n
  • o 检查保留块

某些文件系统(如 ext4)默认保留 5% 的空间给 root 用户:

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

示例输出:

Reserved block count:     524288
  • o 检查文件系统状态
fsck /dev/sda1

注意:运行 fsck 前需卸载文件系统:

umount /dev/sda1
  • o 检查坏块
badblocks -v /dev/sda1

2. 如何解决

  • o 释放 inode

删除不必要的小文件:

find /path -type f -size -1M -delete
  • o 调整保留块比例

将保留块比例从 5% 降到 1%:

tune2fs -m 1 /dev/sda1
  • o 修复文件系统

运行 fsck 修复元数据问题:

fsck -y /dev/sda1
  • o 重建文件系统(极端情况):

如果文件系统损坏严重,备份数据后重建:

mkfs.ext4 /dev/sda1
  • o 预防措施o 创建文件系统时增加 inode 数量:
mkfs.ext4 -i 8192 /dev/sda1
  • o 定期检查文件系统健康状态:
smartctl -a /dev/sda

综合排查流程

为方便读者快速定位问题,这里提供一个综合的排查流程:

  1. 1. 运行基本命令
df -h
du -sh /mount_point
df -i
  1. 2. 检查已删除但未释放的文件
lsof /mount_point | grep deleted
ls -l /proc/*/fd | grep deleted
  1. 3. 检查挂载点覆盖
mount | grep /mount_point
cat /proc/mounts
umount /mount_point && du -sh /mount_point
  1. 4. 检查文件系统元数据
df -i
tune2fs -l /dev/sda1 | grep "Reserved block count"
fsck /dev/sda1
  1. 5. 根据排查结果采取对应措施

总结

df 显示磁盘 100%,但 du 占用少的情况,通常由以下三种原因导致:

  1. 1. 已删除但未释放的文件:进程持有已删除文件的句柄,需通过 lsoffuser 排查并释放。
  2. 2. 挂载点覆盖:新挂载点隐藏了旧文件,需检查 mountfindmnt
  3. 3. 文件系统元数据问题:inode 耗尽、保留块或坏块问题,需通过 df -itune2fsfsck 解决。

预防建议

  • o 定期清理日志和临时文件,使用 logrotatecron 任务。
  • o 挂载前检查目标路径,避免覆盖。
  • o 创建文件系统时合理规划 inode 和保留块比例。
  • o 定期运行 fscksmartctl 检查磁盘健康。

相关推荐

当 Linux 根分区 (/) 已满时如何释放空间?

根分区(/)是Linux文件系统的核心,包含操作系统核心文件、配置文件、日志文件、缓存和用户数据等。当根分区满载时,系统可能出现无法写入新文件、应用程序崩溃甚至无法启动的情况。常见原因包括:...

玩转 Linux 之:磁盘分区、挂载知多少?

今天来聊聊linux下磁盘分区、挂载的问题,篇幅所限,不会聊的太底层,纯当科普!!1、Linux分区简介1.1主分区vs扩展分区硬盘分区表中最多能存储四个分区,但我们实际使用时一般只分为两...

Linux 文件搜索神器 find 实战详解,建议收藏

在Linux系统使用中,作为一个管理员,我希望能查找系统中所有的大小超过200M文件,查看近7天系统中哪些文件被修改过,找出所有子目录中的可执行文件,这些任务需求...

Linux 操作系统磁盘操作(linux 磁盘命令)

一、文档介绍本文档描述Linux操作系统下多种场景下的磁盘操作情况。二、名词解释...

Win10新版19603推送:一键清理磁盘空间、首次集成Linux文件管理器

继上周四的Build19592后,微软今晨面向快速通道的Insider会员推送Windows10新预览版,操作系统版本号Build19603。除了一些常规修复,本次更新还带了不少新功能,一起来了...

Android 16允许Linux终端使用手机全部存储空间

IT之家4月20日消息,谷歌Pixel手机正朝着成为强大便携式计算设备的目标迈进。2025年3月的更新中,Linux终端应用的推出为这一转变奠定了重要基础。该应用允许兼容的安卓设备...

Linux 系统管理大容量磁盘(2TB+)操作指南

对于容量超过2TB的磁盘,传统MBR分区表的32位寻址机制存在限制(最大支持2.2TB)。需采用GPT(GUIDPartitionTable)分区方案,其支持64位寻址,理论上限为9.4ZB(9....

Linux 服务器上查看磁盘类型的方法

方法1:使用lsblk命令lsblk输出说明:TYPE列显示设备类型,如disk(物理磁盘)、part(分区)、rom(只读存储)等。...

ESXI7虚机上的Ubuntu Linux 22.04 LVM空间扩容操作记录

本人在实际的使用中经常遇到Vmware上安装的Linux虚机的LVM扩容情况,最终实现lv的扩容,大多数情况因为虚机都是有备用或者可停机的情况,一般情况下通过添加一块物理盘再加入vg,然后扩容lv来实...

5.4K Star很容易!Windows读取Linux磁盘格式工具

[开源日记],分享10k+Star的优质开源项目...

Linux 文件系统监控:用脚本自动化磁盘空间管理

在Linux系统中,文件系统监控是一项非常重要的任务,它可以帮助我们及时发现磁盘空间不足的问题,避免因磁盘满而导致的系统服务不可用。通过编写脚本自动化磁盘空间管理,我们可以更加高效地处理这一问题。下面...

Linux磁盘管理LVM实战(linux实验磁盘管理)

LVM(逻辑卷管理器,LogicalVolumeManager)是一种在Linux系统中用于灵活管理磁盘空间的技术,通过将物理磁盘抽象为逻辑卷,实现动态调整存储容量、跨磁盘扩展等功能。本章节...

Linux查看文件大小:`ls`和`du`为何结果不同?一文讲透原理!

Linux查看文件大小:ls和du为何结果不同?一文讲透原理!在Linux运维中,查看文件大小是日常高频操作。但你是否遇到过以下困惑?...

使用 df 命令检查服务器磁盘满了,但用 du 命令发现实际小于磁盘容量

在Linux系统中,管理员或开发者经常会遇到一个令人困惑的问题:使用...

Linux磁盘爆满紧急救援指南:5步清理释放50GB+小白也能轻松搞定

“服务器卡死?网站崩溃?当Linux系统弹出‘Nospaceleft’的红色警报,别慌!本文手把手教你从‘删库到跑路’进阶为‘磁盘清理大师’,5个关键步骤+30条救命命令,快速释放磁盘空间,拯救你...

取消回复欢迎 发表评论: