Linux中如何详细分析free -m命令显示的内存使用分布情况?
- 内容介绍
- 文章标签
- 相关推荐
本文共计963个文字,预计阅读时间需要4分钟。
使用Linux的`free -m`命令输出中,`used`列显示的是非真实不可回收的已用内存,它包括大量可立即释放的缓存。真正的反照被进程长期占用、无法腾出的内存,需要查看`MemAvailable`与`used`的差值,并扣除`buffers`和`cached`中实际活跃的部分。
常见误解是看到 used 接近 total 就认为内存快爆了——其实只要 available 还有余量(比如 >10% total),系统就仍在健康状态。
-
used = total - free - buffers - cache,这个公式本身就会把内核主动缓存的内存算进“已用” -
buff/cache是 Linux 内存管理的核心机制,不是泄露,也不是浪费;它会在应用申请内存时自动让出 -
MemAvailable字段(在/proc/meminfo和新版free中可见)才是最可靠的“当前可用物理内存”估算值
为什么 free -m 看到的 used 和 ps/top 加总对不上
因为 used 统计的是内核视角的内存分配状态,而 ps 或 top 的 RSS 只统计每个进程独占或共享的物理页帧,两者统计口径完全不同。
本文共计963个文字,预计阅读时间需要4分钟。
使用Linux的`free -m`命令输出中,`used`列显示的是非真实不可回收的已用内存,它包括大量可立即释放的缓存。真正的反照被进程长期占用、无法腾出的内存,需要查看`MemAvailable`与`used`的差值,并扣除`buffers`和`cached`中实际活跃的部分。
常见误解是看到 used 接近 total 就认为内存快爆了——其实只要 available 还有余量(比如 >10% total),系统就仍在健康状态。
-
used = total - free - buffers - cache,这个公式本身就会把内核主动缓存的内存算进“已用” -
buff/cache是 Linux 内存管理的核心机制,不是泄露,也不是浪费;它会在应用申请内存时自动让出 -
MemAvailable字段(在/proc/meminfo和新版free中可见)才是最可靠的“当前可用物理内存”估算值
为什么 free -m 看到的 used 和 ps/top 加总对不上
因为 used 统计的是内核视角的内存分配状态,而 ps 或 top 的 RSS 只统计每个进程独占或共享的物理页帧,两者统计口径完全不同。

