游乐游手机版
首页/系统平台/文章详情

Linux用ncdu命令查看磁盘空间占用者详解

时间:2026-06-03 06:11
排查服务器磁盘空间告急,是每个运维工程师的必修课。传统的 du -sh * 命令组合固然经典,但在面对海量文件、复杂挂载或特殊文件类型时,不仅速度慢,结果还可能“失真”。这时,一个更高效、更精准的工具就该登场了——ncdu(NCurses Disk Usage)。它直接统计磁盘块占用,不受稀疏文件、

排查服务器磁盘空间告急,是每个运维工程师的必修课。传统的 du -sh * 命令组合固然经典,但在面对海量文件、复杂挂载或特殊文件类型时,不仅速度慢,结果还可能“失真”。这时,一个更高效、更精准的工具就该登场了——ncdu(NCurses Disk Usage)。它直接统计磁盘块占用,不受稀疏文件、硬链接或挂载点干扰,让真正的“空间杀手”无所遁形。

直接运行 ncdu 进行扫描,其速度远超手动拼接 du 命令。关键在于,它统计的是文件实际占用的物理磁盘块(disk blocks),而非文件在逻辑上显示的大小(apparent size)。这意味着,那些看似庞大实则占用极少的稀疏文件(sparse files),或者因硬链接而被重复计算的空间,都不会再干扰你的判断。

为什么 ncdu 显示的大小和 du -sh 不一致

这是新手最常困惑的地方。其实,ncdu 默认界面底部显示的两行信息已经说明了一切:

Total disk usage: 42.3 GiB
Apparent size: 41.9 GiB

第一行“Total disk usage”才是磁盘的真实占用,这与 du -sh(不加 --apparent-size 参数时)的结果是一致的。而第二行“Apparent size”是文件的逻辑大小,也就是你用 ls -lhstat 命令看到的大小。

两者如果出现显著差距,通常指向几种情况:存在大量稀疏文件(例如某些数据库文件、虚拟机磁盘);有文件已被删除但仍有进程在占用(在 /proc/*/fd/ 下可见其“幽灵”);或者目录中存在硬链接,导致逻辑大小被重复统计。记住,你真正该关心的是第一行,那才是吃掉你磁盘空间的“真凶”。

扫描时必须加 -x 参数的三种情况

-x 参数是 ncdu 的“定海神针”,它告诉工具不要跨越文件系统边界进行扫描。不加它,很容易误入其他挂载点,导致扫描结果失真,甚至进程卡死。下面三种场景务必加上:

  • 清理根分区时:运行 sudo ncdu -x /。这能避免工具跳进 /boot/proc/sys 这类独立的或伪文件系统,确保扫描范围锁定在你想要检查的根文件系统内。
  • 排查 /var 空间暴增时:使用 sudo ncdu -x /var。像 /var/lib/docker 下的 overlay2 存储驱动目录,很可能是一个独立的卷或挂载点。不加 -xncdu 可能会将其当作普通目录反复遍历,既耗时又可能引发问题。
  • 在容器宿主机上检查用户家目录时:执行 ncdu -x ~。现代桌面环境中,家目录下可能存在像 .local/share/flatpak 这样的绑定挂载点,加上 -x 可以防止意外扫描进入,确保结果准确反映当前家目录所在文件系统的使用情况。

交互界面里删错文件怎么办

ncdu 的交互式界面中,按 d 键可以直接删除文件或目录,这是一个强大但危险的功能。因为它执行的是真实的 unlink 系统调用,没有回收站可言。不过,工具本身设计了两道安全防线:

第一道是确认提示:按下 d 后,界面底部会弹出确认框,必须输入 y 并按回车才会执行删除。
第二道是系统保护:如果要删除的文件正被某个进程占用(比如正在被 tail -f 追踪的日志),删除操作会失败,并在界面右下角显示 Cannot remove: Device or resource busy 的错误信息。

但要注意,有些情况它可能“静默”处理得不彻底。例如,直接删除 /var/log/journal 下的系统日志文件,虽然文件消失了,但日志索引可能残留,空间并未完全释放。更稳妥的做法是先停止相关服务:sudo systemctl stop systemd-journald,然后在 ncdu 中执行删除,完成后再启动服务:sudo systemctl start systemd-journald

扫描卡住或内存爆满时的应急操作

当面对一个数十TB的NAS挂载点,或者系统本身内存紧张时,ncdu 的扫描过程可能会变得缓慢甚至耗尽资源。别慌,有几个应急技巧:

  • 随时可以按 Ctrl+C 中断扫描。ncdu 会立即进入已扫描完成部分的交互界面,你至少可以查看当前已发现的前几十个最大项目,这通常已经能定位到主要问题了。
  • 使用 --exclude 参数预先排除已知的、无需检查的目录,可以大幅提升扫描效率。例如:ncdu --exclude '/home/*/.cache' --exclude '/tmp' /home
  • 对于需要反复检查的目录,可以预生成扫描快照:ncdu -o ~/ncdu-root.dat -x /。这个命令会将扫描结果输出到文件,之后只需运行 ncdu -f ~/ncdu-root.dat,就能瞬间加载之前的扫描结果进行分析,无需重新扫描。

最后,必须清醒认识到,ncdu 再强大,也只能统计文件系统上可见的文件占用。真正的“幽灵占用”——那些已被删除(unlinked)但仍被进程打开的文件,是不会出现在 ncdu 的列表里的。这类情况会导致“可用空间”与统计结果对不上。此时,就需要借助 lsof +L1 这样的命令,到 /proc 文件系统层面去追踪并释放这些被进程占用的磁盘空间了。工具虽好,但理解其原理和边界,才能运用自如。

来源:https://www.php.cn/faq/2400432.html
上一篇Win11任务栏日期显示不全的调整高度方法 下一篇Windows蓝屏代码0x0000009f驱动电源状态切换修复方法
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
Windows系统关闭完成设备设置提示禁用开机引导方法
系统平台 · 2026-06-03

Windows系统关闭完成设备设置提示禁用开机引导方法

Windows开机时“完成设备设置”提示常因OOBE流程未完成、账户同步残留或系统推荐服务引起。本文提供五种解决方法:关闭登录选项中的自动设置复原;禁用系统通知中的引导提示;清除本地OOBE缓存;修改注册表标记OOBE已完成;关闭账户同步的设置推荐服务。用户可按需选择处理。

Win10更新后变卡,关闭更新恢复系统流畅度
系统平台 · 2026-06-03

Win10更新后变卡,关闭更新恢复系统流畅度

电脑刚刚完成Windows 10更新,却感觉运行变得迟钝?鼠标拖拽不顺畅,程序启动缓慢,风扇持续高速运转——这是不少用户都曾遇到的困扰。别急着认定是硬件老化,问题很可能就出在本次更新上。新补丁有时会引发驱动兼容性问题,或意外激活某些非必要的后台服务,导致系统资源被悄悄消耗。 不必担心,以下方法能帮你

Win11更新导致音频服务消失 修复声卡服务教程
系统平台 · 2026-06-03

Win11更新导致音频服务消失 修复声卡服务教程

Win11系统更新后,任务栏音量图标突然失效,设备管理器中声卡驱动显示正常却没有任何声音输出——如果你正被这个问题困扰,那很可能是系统更新误删了音频服务的核心注册表配置。别担心,这通常不是硬件故障,只需按照以下系统化修复步骤操作,大概率能恢复音频功能。 一、强制重建音频服务注册表与可执行路径 声音消

统信UOS系统管理启动内核并切换旧版本的方法
系统平台 · 2026-06-03

统信UOS系统管理启动内核并切换旧版本的方法

在使用统信UOS系统时,系统更新后新内核与硬件出现兼容性问题并不罕见——例如网卡突然无法连接、显卡渲染出现异常,或是触摸板完全失灵。遇到这种情况不必急着重装系统,多数时候只需手动切换回一个经过验证的旧版内核,问题就能顺利解决。下面这份操作指南将带你一步步完成从排查到永久切换的完整流程。 一、查看当前

Win11系统托盘永久显示关闭自动隐藏技巧
系统平台 · 2026-06-03

Win11系统托盘永久显示关闭自动隐藏技巧

你是否也曾为Windows 11任务栏右下角的系统托盘图标自动隐藏而感到困扰?常用的网络、音量或第三方应用图标总是悄悄“折叠”起来,必须点击那个小箭头才能展开查看。这其实是系统默认的“动态隐藏”策略在起作用,旨在保持任务栏简洁。但如果你和我一样,更希望所有图标一目了然、随时可用,那么彻底关闭这个自动