如何在Linux中检查磁盘使用率 Linux df与du命令对比

df命令查看文件系统整体空间使用情况,du命令统计目录或文件实际占用空间;df基于文件系统元数据快速显示挂载点使用状态,du通过遍历目录计算具体空间消耗;二者差异常因已删除但被进程占用的“幽灵文件”导致数据不一致;使用df -h可快速识别高使用率分区,结合-i可检查inode耗尽问题,而du -sh与–max-depth配合sort命令能精准定位占用空间大的目录或文件。

如何在linux中检查磁盘使用率 linux df与du命令对比

在Linux系统里检查磁盘使用率,通常会用到

df

du

这两个命令。简单来说,

df

关注的是整个文件系统的空间使用情况,告诉你还有多少“空地”;而

du

则深入到目录和文件层面,帮你找出具体是哪些文件或文件夹占用了空间。它们各自有其擅长的场景,理解它们的区别能让你更高效地管理磁盘。

解决方案

要检查Linux中的磁盘使用率,最直接的方式就是运用

df

du

命令。

使用

df

命令查看文件系统整体使用情况:

df

(disk free)命令用于显示文件系统上的可用磁盘空间。它读取的是文件系统的元数据,所以能快速给出整个挂载点的信息。

常用选项:

-h

:以人类可读的格式(如G、M)显示大小。

-T

:显示文件系统类型。

-i

:显示inode使用情况。

示例:

df -h # 显示所有文件系统的磁盘使用情况,人类可读df -h /home # 仅显示/home分区的磁盘使用情况df -hT # 显示文件系统类型和磁盘使用情况

使用

du

命令查看目录或文件占用空间:

du

(disk usage)命令用于估算文件或目录的磁盘空间使用量。它会遍历指定目录下的所有文件和子目录,并累加它们的大小。

常用选项:

-h

:以人类可读的格式显示大小。

-s

:仅显示总计(summarize)。

-c

:显示所有参数的总计。

--max-depth=N

:仅显示指定深度内的目录使用情况。

示例:

du -sh /var/log # 汇总显示/var/log目录的总大小du -h --max-depth=1 / # 显示根目录下各一级子目录的大小du -h /path/to/your/dir # 显示指定目录及其子目录的详细大小

df

du

命令的核心差异是什么?

这是个经常让人困惑的问题,甚至有时候你会发现它们给出的数字完全对不上号。在我看来,理解它们的根本工作方式是关键。

df

命令,它就像是一个站在高处的管理员,它看的是整个仓库(文件系统)还剩下多少空间,以及已经使用了多少。它直接查询文件系统的超级块(superblock)信息,快速得出结论。所以,当你想知道

/dev/sda1

这个分区是不是快满了,或者

/var

挂载点是不是空间告急,

df

就是你的首选。它给出的数据是文件系统层面的“可用空间”和“已用空间”。

du

命令,它更像是一个勤劳的审计员,它会逐个房间(目录)去清点每个箱子(文件)的大小,然后把所有箱子的大小加起来。所以,

du

的结果是实际文件占用的空间总和。当你发现某个分区快满了,但又不知道具体是哪个文件夹在“捣鬼”时,

du

就能帮你一层层地剥开,找到那个真正占用大空间的元凶。

它们之间最常见的差异来源,往往是那些“幽灵文件”——也就是已经被删除,但仍然被某个进程打开着的文件。

df

会认为这些文件占用的空间还没有被释放,因为它还在文件系统上被标记为“使用中”。但

du

在遍历目录时,这些文件已经不在目录树里了,所以它不会把它们计算在内。结果就是,

df

显示空间不足,但

du

却告诉你总和没那么大。这时候,通常需要重启相关服务或者进程,才能真正释放这些空间。还有一些情况,比如稀疏文件(sparse files)或者硬链接,也会导致两者数据不完全一致,但“幽灵文件”是最常见的场景。

如何有效利用

df

命令检查磁盘空间?

df

命令在日常系统维护中非常有用,它能让你快速掌握各个挂载点的健康状况。我通常会这样做:

MiniMax Agent MiniMax Agent

MiniMax平台推出的Agent智能体助手

MiniMax Agent 839 查看详情 MiniMax Agent

1. 快速概览:运行

df -h

是我的第一步。这能让我一眼看到所有挂载点(包括物理分区、虚拟文件系统如

tmpfs

devtmpfs

等)的使用情况,以及它们各自的容量、已用、可用空间和使用百分比。如果看到某个分区的利用率接近90%甚至更高,那我就知道需要重点关注了。

df -h

输出会类似这样:

文件系统        容量  已用  可用 已用% 挂载点udev            3.9G     0  3.9G    0% /devtmpfs           798M  1.6M  797M    1% /run/dev/sda1        40G   35G  2.5G   94% /tmpfs           3.9G     0  3.9G    0% /dev/shmtmpfs           5.0M  4.0K  5.0M    1% /run/lock/dev/sda2       100G   50G   50G   50% /hometmpfs           798M   12K  798M    1% /run/user/1000

这里,

/dev/sda1

的使用率达到了94%,这通常意味着该分区快满了,需要立即处理。

2. 关注特定分区:如果我知道某个服务的数据都放在

/var

目录下,我会直接

df -h /var

来查看它的独立空间情况,而不是在茫茫列表中寻找。

df -h /var

3. 检查inode使用情况:有时候,磁盘空间明明还有很多,但你却无法创建新文件。这很可能是因为inode(索引节点)用完了。Inode是文件系统用来存储文件元数据(如文件大小、权限、所有者、时间戳等)的数据结构。每个文件或目录都需要一个inode。在处理大量小文件(比如邮件服务器、Web缓存)时,inode耗尽是个常见问题

df -hi # 检查所有文件系统的inode使用情况

如果看到某个分区的

IUse%

很高,即使

Use%

不高,也说明inode快用完了。

4. 过滤不关心的文件系统:对于日常监控,我通常不关心

tmpfs

devtmpfs

udev

这类虚拟文件系统,因为它们是内存文件系统或设备文件系统,不会真正耗尽物理磁盘空间。可以使用

-x

选项排除它们:

df -hT -x tmpfs -x devtmpfs -x udev

这样输出会更干净,只显示你真正关心的物理磁盘挂载点。

如何有效利用

du

命令查找大文件或目录?

df

告诉你某个分区快满了,

du

就成了你的侦探工具,帮你揪出那些“空间大户”。它的使用场景非常灵活。

1. 快速定位当前目录总大小:进入一个你怀疑有问题的大目录,比如

/var/log

,然后运行:

cd /var/logdu -sh .

.

代表当前目录,

-s

汇总,

-h

人类可读。这会告诉你当前目录的总大小。

2. 找出子目录中的“胖子”:如果

/var/log

很大,我想知道是哪个子目录贡献了大部分空间,我就会使用

--max-depth

sort

命令:

du -h --max-depth=1 /var/log | sort -rh

-h

人类可读,

--max-depth=1

只显示一级子目录,

sort -rh

按照人类可读的大小逆序排序,最大的排在最前面。这通常能快速定位到像

apache2

nginx

mysql

这类服务产生的巨型日志目录。

3. 查找整个文件系统中的大文件(需要谨慎):如果你想全局查找,但又不想遍历

/proc

/sys

这些虚拟文件系统,可以使用

--exclude

du -h --exclude=/proc --exclude=/sys --exclude=/dev --max-depth=1 / | sort -rh

这会显示根目录下所有一级子目录的大小,并排除掉那些不实际占用磁盘空间或不应被遍历的目录。

4. 结合

find

命令查找特定类型的大文件:假设你想找出所有大于1GB的

.log

文件:

find / -name "*.log" -type f -size +1G -print0 | xargs -0 du -h

find

命令在这里负责找到符合条件的文件,

-print0

xargs -0

确保文件名中即使有空格或特殊字符也能正确处理,然后

du -h

对这些找到的文件进行大小统计。

5. 找出某个目录下的前N个大文件:这在清理日志或缓存时非常实用。

du -a /path/to/dir | sort -n -r | head -n 10

-a

会列出所有文件和目录的大小,

sort -n -r

按数字逆序排序,

head -n 10

只显示前10行。如果想看人类可读的格式,可以这样:

du -ah /path/to/dir | sort -rh | head -n 10

需要注意的是,

du

在处理大量文件时可能会比较慢,尤其是在大容量磁盘上。所以,通常建议先用

df

确定大方向,再用

du

缩小范围,一步步地定位问题。

以上就是如何在Linux中检查磁盘使用率 Linux df与du命令对比的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/721693.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
mac怎么开启屏幕键盘_Mac开启屏幕键盘方法
上一篇 2025年11月24日 15:40:28
手机qq浏览器怎么把小说添加到书架_手机qq浏览器小说收藏方法
下一篇 2025年11月24日 15:40:35

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    1000
  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • 利用海象运算符简化条件赋值:Python教程与最佳实践

    本文旨在探讨Python中海象运算符(:=)在条件赋值场景下的应用。通过对比传统if/else语句与海象运算符,以及条件表达式,分析海象运算符在简化代码、提高可读性方面的优势与局限性。并通过具体示例,展示如何在列表推导式等场景下合理使用海象运算符,同时强调其潜在的复杂性及替代方案,帮助开发者更好地掌…

    2026年5月10日
    100
  • Debian syslog性能优化技巧有哪些

    提升Debian系统syslog (通常基于rsyslog)性能,关键在于精简配置和高效处理日志。以下策略能有效优化日志管理,提升系统整体性能: 精简配置,高效加载: 在rsyslog配置文件中,仅加载必要的输入、输出和解析模块。 使用全局指令设置日志级别和格式,避免不必要的处理。 自定义模板: 创…

    2026年5月10日
    000
  • 怎么在PHP代码中实现图片上传功能_PHP图片上传功能实现与安全处理教程

    首先创建含enctype的HTML表单,再用PHP接收文件,检查目录、移动临时文件,验证类型与大小,生成唯一文件名,并调整php.ini限制以确保上传成功。 如果您尝试在PHP项目中添加图片上传功能,但服务器无法正确接收或保存文件,则可能是由于表单配置、文件处理逻辑或安全限制的问题。以下是实现该功能…

    2026年5月10日
    100
  • c++中的SFINAE技术是什么_c++模板编程中的SFINAE原理与应用

    SFINAE 是“替换失败不是错误”的原则,指模板实例化时若参数替换导致错误,只要存在其他合法候选,编译器不报错而是继续重载决议。它用于条件启用模板、类型检测等场景,如通过 decltype 或 enable_if 控制函数重载,实现类型特征判断。尽管 C++20 引入 Concepts 简化了部分…

    2026年5月10日
    000
  • Golang goroutine与channel调试技巧

    使用go run -race检测数据竞争,结合runtime.NumGoroutine监控协程数量,通过pprof分析阻塞调用栈,利用select超时避免永久阻塞,有效排查goroutine泄漏、死锁和数据竞争问题。 Go语言的goroutine和channel是并发编程的核心,但它们也带来了调试上…

    2026年5月10日
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • php常量怎么用_PHP常量(define/const)定义与使用方法

    PHP中可通过define函数和const关键字定义常量,用于存储不可变值。define适用于全局作用域,支持动态名称和条件定义,如define(‘SITE_NAME’, ‘MyWebsite’);const在编译时生效,语法简洁但限制多,只能在类或全…

    2026年5月10日
    000
  • 网站标题关键词更新后,搜索引擎为何仍显示旧标题?

    网站标题更新后,搜索引擎为何显示旧标题? 网站SEO优化中,站长常修改网站标题关键词,期望搜索结果显示自定义标题。然而,即使更新标签、meta keywords、meta description和结构化数据中的name属性后,搜索结果仍显示旧标题,这令人费解。本文将对此进行解释。 问题:站长修改了网…

    2026年5月10日
    100
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • 如何插入查询结果数据_SQL插入Select查询结果方法

    如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法

    使用INSERT INTO…SELECT语句可高效插入数据,通过NOT EXISTS、LEFT JOIN、MERGE语句或唯一约束避免重复;表结构不一致时可通过别名、类型转换、默认值或计算字段处理;结合存储过程可提升可维护性,支持参数化与动态SQL。 将查询结果数据插入到另一个表中,可以…

    2026年5月10日 用户投稿
    000
  • python中zip函数详解 python多序列压缩zip函数应用场景

    zip函数的应用场景包括:1) 同时遍历多个序列,2) 合并多个列表的数据,3) 数据分析和科学计算中的元素运算,4) 处理csv文件,5) 性能优化。zip函数是一个强大的工具,能够简化代码并提高处理多个序列时的效率。 在Python中,zip函数是一个非常有用的工具,它能够将多个可迭代对象打包成…

    2026年5月10日
    000
  • c++如何实现UDP通信_c++基于UDP的网络通信示例

    UDP通信基于套接字实现,适用于实时性要求高的场景。1. 流程包括创建套接字、绑定地址(接收方)、发送(sendto)与接收(recvfrom)数据、关闭套接字;2. 服务端监听指定端口,接收客户端消息并回传;3. 客户端发送消息至服务端并接收响应;4. 跨平台需处理Winsock初始化与库链接,编…

    2026年5月10日
    000
  • 谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    使用谷歌浏览器的开发者工具截图步骤:1. 按ctrl+shift+i(windows/linux)或cmd+option+i(mac)打开开发者工具。2. 点击右上角三个点,选择”更多工具”,再选择”截图”。3. 选择截取整个页面。推荐的谷歌浏览器扩展…

    2026年5月10日 用户投稿
    100
  • Python中怎样使用pymongo?

    在python中使用pymongo可以轻松地与mongodb数据库进行交互。1)安装pymongo:pip install pymongo。2)连接到mongodb:from pymongo import mongoclient; client = mongoclient(‘mongod…

    2026年5月10日
    000
  • JS如何实现迭代器?迭代器协议

    JavaScript中实现迭代器需遵循可迭代协议和迭代器协议,通过定义[Symbol.iterator]方法返回具备next()方法的迭代器对象,从而支持for…of和展开运算符;该机制统一了数据结构的遍历接口,实现惰性求值,适用于自定义对象、树、图及无限序列等复杂场景,提升代码通用性与…

    2026年5月10日
    000
  • JavaScript函数中插入加载动画(Spinner)的正确方法

    本文旨在解决在JavaScript函数中插入加载动画(Spinner)时遇到的异步问题。通过引入async/await和Promise.all,确保在数据处理完成前后正确显示和隐藏加载动画,提升用户体验。我们将提供两种实现方案,并详细解释其原理和优势。 在Web开发中,当执行耗时操作时,显示加载动画…

    2026年5月10日
    000
  • Golang空接口如何应用在项目中

    空接口可用于接收任意类型值,常见于日志函数、通用数据结构、JSON动态解析及配置驱动逻辑,提升代码灵活性,但需配合类型断言确保安全,避免滥用以降低维护成本。 空接口 interface{} 在 Go 语言中是一个非常灵活的类型,它可以存储任何类型的值。虽然它牺牲了一部分类型安全,但在实际项目中合理使…

    2026年5月10日
    100
  • MySQL数据库不支持中文的解决办法

    接上一篇文章,在解决了mysql+flask环境配置问题之后,往数据库存中文字符串会报1366错误,提示不正确的字符。继而发现默认的mysql采用了latin1字符集,这种编码是不支持中文的。 如果想支持中文的话,需要设置一下mysql字符集。 众所周知utf-8是可以的,gbk也没问题,为了可扩展…

    用户投稿 2026年5月10日
    000

发表回复

登录后才能评论
关注微信