商城首页欢迎来到中国正版软件门户

您的位置:首页 >Linux查看CPU和内存占用情况 top和free命令【教程】

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

  发布于2026-04-29 阅读(0)

扫一扫,手机访问

别被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 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注