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

Linux查看CPU和内存占用情况 top和free命令【教程】

时间:2026-04-29 14:13
别被top的“内存耗尽”骗了:看懂a vailable才是关键 在Linux系统里判断内存是否真的不够用,一个最常见的误区就是只看top命令。很多人一看到used值接近总量就慌了,其实这很可能是个假警报。真正决定系统内存余量的,是free命令输出的a vailable字段,而不是top里的used或

别被top的“内存耗尽”骗了:看懂a vailable才是关键

Linux查看CPU和内存占用情况 top和free命令【教程】

在Linux系统里判断内存是否真的不够用,一个最常见的误区就是只看top命令。很多人一看到used值接近总量就慌了,其实这很可能是个假警报。真正决定系统内存余量的,是free命令输出的a vailable字段,而不是top里的usedfree值。

简单来说,a vailable反映的是当前能立即分配给新进程的物理内存,而top显示的used包含了大量可以被内核随时回收的缓存,这直接导致了误判。

为什么 top 的内存数据不能直接判断内存是否不够用

问题出在top命令第四行(KiB Mem)的统计口径上。这里的used值是一个“总分配量”,它把内核缓存(page cache)、slab、buffers等都算了进去。而这些内存,绝大多数情况下都是可以被系统快速回收的,并非被进程“独占”。另一方面,free值又只计算完全空闲、未被使用的内存页,这个数字又过于保守。

于是,尴尬的局面就出现了:这两个数字都无法准确回答“此刻还能给新进程分配多少物理内存”这个核心问题。

由此引发的误判场景比比皆是:

  • 看到used: 1.5G / total: 2G就以为内存快爆了,急忙去杀进程,殊不知a vailable可能还剩1.1G,系统其实很宽松。
  • 杀掉一个top里显示%MEM很高的进程后,系统反而更卡了。这是因为你清除了该进程带来的缓存,导致后续磁盘读取操作猛增。
  • 只盯着top%MEM排序,可能忽略了“多个小进程合起来吃光a vailable”这种更隐蔽的真瓶颈。

free -h 怎么看才对:盯死 a vailable 和 buff/cache

正确的方法是运行free -h,然后把目光锁定在两处:

  • Mem:行末的a vailable:这是内核估算出的、当前可立即分配给新进程的物理内存。它已经扣除了不可回收的slab等部分,并合理评估了page cache中可回收的部分,是目前最可靠的“余量”指标。
  • buff/cache:这个值高本身不等于有问题。Linux的策略就是利用空闲内存做缓存来提升性能。只要a vailable大于总内存的10%,通常就无需干预。

那么,什么时候才需要警惕呢?当a vailable持续低于总内存的5%,并且swap used开始持续增长时,这才是内存真正紧张的明确信号。

来看一个示例输出片段:

Mem:           1.8G        330M       813M       739M       1.4G

这里的关键是最后一列的数值1.4G,它代表的就是a vailable(注意看表头,不是找“a vail Mem”字样,而是第五列对应的数值)。这说明系统还有1.4G的物理内存可以随时调用,余量充足。

top 里哪些字段真有用,哪些该忽略

虽然top不适合判断总体内存水平,但在定位“谁在吃内存”时依然是一把利器,前提是得看对字段。

  • 按下Shift+M按内存排序后,优先关注RES(Resident Memory Size,常驻内存集)。它表示进程实际占用的物理内存大小。VIRT(虚拟内存)包含太多东西(如mmap映射、swap空间、未实际分配的地址空间),参考意义不大。
  • %MEMRES占总物理内存的百分比,可以作为相对参考。但真正决定一个进程内存影响大小的,是RES的绝对值(单位是KiB)。
  • 可以忽略旧版top中可能存在的SWAP列。它通常显示的是进程的swap in/out速率,而不是当前占用的swap空间量。
  • 如果发现某个进程RES异常高,怀疑内存泄漏,可以用命令cat /proc//status | grep -E "VmRSS|MMUPageSize"做进一步确认。

当 a vailable 确实很低时,下一步查什么

如果确认a vailable真的告急了,先别急着杀进程或者盲目增加swap。第一步是排除缓存策略导致的假象,并精准定位问题源头。

  • 验证估算逻辑:查看/proc/meminfo文件,对比MemA vailableBuffersCachedSReclaimable等字段的关系,理解free命令的a vailable是如何计算出来的。
  • 确认swap真实使用:运行vmstat 1 5,观察si(swap in)和so(swap out)列。如果它们持续为非零值,才说明swap正在被频繁使用,内存压力真实存在。
  • 定位独占内存:使用smem -w工具查看各进程的USS(Unique Set Size,唯一驻留集)。这个指标比RES更能准确反映一个进程“独占”的、无法被共享的内存,是找出内存大户的利器。
  • 注意容器环境:在Docker或Kubernetes环境中,宿主机上的topfree会失真。容器的真实内存用量要看docker stats或对应cgroup的memory.current值。

最后必须强调一点:Linux的缓存机制本身就是一种性能优化。除非你明确知道缓存内容已经过期且不可再生,否则千万不要轻易执行echo 3 > /proc/sys/vm/drop_caches这类操作。强行清空缓存只会导致后续的磁盘IO变慢,让系统性能不升反降。

来源:https://www.php.cn/faq/2388462.html
上一篇Linux下如何查看进程的系统调用耗时 Strace -c命令用法 下一篇Win10怎么设置家长控制_Win10家长控制教程【避坑】
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

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

同类最新

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

更多
微软详解Win11时间点还原 默认每24小时创建恢复点
系统平台 · 2026-06-30

微软详解Win11时间点还原 默认每24小时创建恢复点

微软今日推送了最新的 6 月可选更新,并发布博客详细解读了 Win11 全新的“时间点还原”(Point-in-time restore)功能——这一功能本质上是对系统恢复体验的一次全面升级,旨在让用户更轻松地应对电脑故障。 微软表示,面向 Windows 11 客户端用户的“时间点还原”功能现已正

Win11 26H1六月可选更新KB5095091 优化放大镜改善装机体验
系统平台 · 2026-06-30

Win11 26H1六月可选更新KB5095091 优化放大镜改善装机体验

微软今天推送了Windows 11 26H1设备的6月可选更新KB5095091,安装完成后系统版本号会升级到Build 28000 2340。值得一提的是,这次更新并非面向所有设备,而是专门为搭载高通骁龙X2系列芯片的机型准备的——包括骁龙X2 Plus、X2 Elite和X2 Elite Ext

Win11六月可选更新KB5095093修复回收站弹窗异常
系统平台 · 2026-06-30

Win11六月可选更新KB5095093修复回收站弹窗异常

微软已悄然推送Windows 11六月可选更新,编号KB5095093。本次更新覆盖两个版本:24H2用户安装后版本号升级至Build 26100 8737,而25H2用户则更新至Build 26200 8737。 本次更新并非仅是小修小补,而是带来了多项实质性新功能。下面我们就来详细解析这些更新内

苹果macOS 27 Beta2封堵Siri AI跳过候补名单漏洞
系统平台 · 2026-06-30

苹果macOS 27 Beta2封堵Siri AI跳过候补名单漏洞

科技媒体 Cult of Mac 昨日(6月23日)发布博文指出,苹果在 macOS 27 Beta 2 更新中悄然封堵了一个此前可用的后门——用户曾能通过一条终端命令绕过候补名单,直接启用新版 Siri AI,如今这一方法已失效。 简要回顾一下:在 macOS 27 Beta 1 阶段,只需在 M

微软加速Win11 25H2推送 覆盖所有符合条件家用PC
系统平台 · 2026-06-30

微软加速Win11 25H2推送 覆盖所有符合条件家用PC

近日(6月23日),科技媒体 Windows Latest 发布了一则值得关注的动态:微软已进一步扩大 Windows 11 25H2 的推送范围,所有满足硬件要求、且不受 IT 部门管理的家庭版和专业版设备,现在均可顺利接收本次更新。 此次升级有一个显著特点——采用“启用包”(eKB)方式进行推送