登录
首页 >  文章 >  linux

Linux进程内存查看方法详解

时间:2026-04-24 18:30:52 253浏览 收藏

本文深入解析了Linux中通过/proc/[pid]/status文件精准获取进程内存使用状况的核心方法,揭示VmRSS、VmSize、VmData等关键字段的含义与实战价值——它们不仅是内核原生提供的毫秒级精确快照,更是诊断内存峰值(VmHWM)、识别虚拟内存膨胀、排查隐性泄漏(如“分配未触达”的剪刀差问题)及厘清swap真实行为(VmSwap≠swap历史)的第一手依据;同时澄清了与ps命令数值差异的根源,并指出在多线程、容器、JVM等复杂场景下如何选择更可靠的替代工具与指标,堪称Linux内存分析的实用指南。

Linux怎么查看进程的内存分级统计 Linux下/proc/pid/status详解

怎么看 /proc/[pid]/status 里的内存字段

直接读这个文件就能拿到进程最细粒度的内存分级统计,不需要额外工具或解析逻辑。它不是“概览”,而是内核原生输出的、带单位的精确快照。

关键内存字段都在 Vm* 开头的行里,比如:

Name:   nginx
State:  S
...
VmPeak:    124568 kB
VmSize:    124568 kB
VmLck:         0 kB
VmHWM:      5240 kB
VmRSS:      5240 kB
VmData:     4892 kB
VmStk:        88 kB
VmExe:       320 kB
VmLib:      2044 kB
VmPTE:        56 kB
VmSwap:        0 kB
  • VmRSS 是常驻物理内存(实际占 RAM 的部分),对应 psRSStopRES
  • VmSize 是整个虚拟地址空间大小(含未分配页、mmap 区等),对应 psVSZ
  • VmData 是堆 + 数据段大小,VmStk 是栈,VmExe 是代码段,VmLib 是共享库映射 —— 这些加起来≈VmSize,但不严格相等(因 mmap 区、vvar/vdso 等未计入)
  • VmHWM 是该进程生命周期中达到过的最高 VmRSS,比当前 VmRSS 更能反映内存峰值压力
  • VmPeak 是虚拟内存历史峰值,一般等于 VmSize,除非进程曾释放过大块虚拟地址空间(如 munmap)

为什么 VmRSSps auxRSS 值有时不一致

本质是采样时机和统计口径不同:前者是读取时瞬间快照,后者是 ps 遍历所有进程时统一采集,中间可能有毫秒级偏差;更常见的是 ps 默认显示单位为 KB,但不补零,而 /proc/[pid]/status 总是带单位且对齐。

  • 确认是否同一时刻:用 cat /proc/$(pgrep -f "your_cmd")/status | grep VmRSSps -o pid,rss,comm -C your_cmd 对比,避免时间差干扰
  • 检查进程是否多线程:VmRSS 是整个线程组(Tgid)的总 RSS,而 ps 默认按线程(LWP)显示,若用 ps -eLf 就会看到多个同 Tgid 的线程共享一份 VmRSS
  • 某些容器环境(如 runc)会限制 VmRSS 上报精度,此时应优先信 smem -p [pid]PSS

VmSwap 为 0 不代表没发生过 swap

VmSwap 只反映当前被换出到 swap 分区的页数,不是累计值,也不是 swap-in/out 计数器。它清零后不会保留历史痕迹。

  • 如果怀疑进程被 swap 过,得结合 /proc/[pid]/statmin_flt(次缺页)和 maj_flt(主缺页):大幅增长的 maj_flt 往往意味着频繁 swap-in
  • /proc/[pid]/smaps 更有用:里面每个内存段都有 Swap: 行,还能看到 SwapPss:(按比例分摊的 swap 占用)
  • cat /proc/swaps 看系统级 swap 使用,再用 grep -i swap /proc/[pid]/smaps 定位具体哪些映射区域被换出

排查内存泄漏时,别只盯 VmRSS

很多泄漏发生在用户态 malloc 层(如 glibc 的 arena),VmRSS 涨得慢甚至不涨 —— 因为内核还没把 brk/mmap 分配的页真正映射进物理内存。

  • 先看 VmSize 是否持续上涨:说明程序在不断申请虚拟地址空间(如反复 mmap 或大块 malloc)
  • 再查 /proc/[pid]/smaps_rollup(如有)或遍历 /proc/[pid]/smaps 中的 Size:RSS: 总和,对比两者差值是否扩大(即“已分配但未使用”的页增多)
  • 对 C/C++ 程序,用 malloc_info(3) 输出堆内部结构,或挂 gdb --pid [pid] 后执行 call malloc_stats()
  • Java 进程则要跳过 /proc/[pid]/status,直接用 jstat -gc [pid],因为 JVM 内存管理完全绕开了内核的 Vm* 统计

真正难定位的泄漏,往往卡在 VmSizeVmRSS 的“剪刀差”里 —— 那些被分配却长期没 touch 的页,既不增加 RSS,也不触发 OOM,但会悄悄吃掉虚拟地址空间。

今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>