在Linux系统中,监控程序的内存使用情况是系统管理和性能优化的核心任务之一,通过查看内存占用,可以快速定位内存泄漏、资源耗尽等问题,确保系统稳定运行,本文将详细介绍多种常用命令及其使用方法,帮助用户全面掌握Linux内存监控技巧。

基础命令:快速查看进程内存占用
ps命令:静态查看进程状态
ps(Process Status)是Linux中最基础的进程查看工具,通过结合参数可以快速获取进程的内存使用情况。
-
常用参数:
aux:显示所有进程的详细信息,包括内存占用(VSZ和RSS)。--sort=-%mem:按内存使用率降序排序,便于定位高内存进程。-o pid,ppid,cmd,%mem,rss:自定义输出列,仅显示进程ID、父进程ID、命令、内存占比和物理内存大小。
-
示例:
ps aux --sort=-%mem | head -10 # 查看内存占用最高的前10个进程
-
关键字段解释:
VSZ(Virtual Memory Size):虚拟内存大小,包括进程使用的所有虚拟地址空间(如代码段、数据段、共享库等),单位为KB。RSS(Resident Set Size):常驻内存集大小,表示进程实际占用的物理内存(不包括swap分区),单位为KB。
top命令:实时动态监控
top命令以动态刷新的方式展示进程资源占用,适合实时监控内存变化。
-
核心操作:
- 按
M:按内存使用率(%MEM)降序排序。 - 按
P:按CPU使用率排序(默认)。 - 按
d:修改刷新间隔(默认3秒)。 - 按
k:终止指定进程(需输入PID)。
- 按
-
示例:
top -d 1 -o +%MEM # 每秒刷新,按内存使用率排序
-
关键字段解释:

VIRT:虚拟内存总量(同VSZ)。RES:物理内存占用(同RSS)。%MEM:进程物理内存占用率(RES/总物理内存×100%)。
htop命令:增强版交互式监控
htop是top的升级版,支持鼠标操作、进程树显示、颜色区分等功能,用户体验更友好。
-
核心优势:
- 树状结构展示进程父子关系(按
F5切换)。 - 实时显示内存条(直观展示系统内存使用情况)。
- 支持横向滚动查看完整命令行。
- 树状结构展示进程父子关系(按
-
示例:
htop # 直接启动,默认按CPU排序,按F6选择排序方式(如MEM)
进阶命令:深度分析内存分配
pmap命令:查看进程内存映射
pmap(Process Memory Map)用于显示进程的内存段分布,可分析堆、栈、共享库等具体内存占用,适合定位内存泄漏或异常内存分配。
-
常用参数:
x:显示详细内存映射(包括权限、偏移量、设备号等)。
-d:显示内存段统计信息(如总占用、私有/共享内存)。
-
示例:
pmap -x PID # 查看指定进程的详细内存映射
-
输出解读:
Address:内存起始地址。Kbytes:内存段大小(单位KB)。RSS:该段实际占用的物理内存。Mode:内存权限(如r=读,w=写,x=执行)。
smem命令:计算实际内存占用
smem工具解决了RSS统计中共享内存重复计算的问题,通过计算“比例集大小(PSS)”更准确地反映进程对物理内存的实际占用。

- 安装:
sudo apt install smem # Debian/Ubuntu sudo yum install smem # CentOS/RHEL
- 示例:
smem -p PID # 查看指定进程的PSS内存占用 smem --show pid pss command # 显示所有进程的PID、PSS和命令
- 关键指标:
PSS(Proportional Set Size):进程占用的物理内存按比例分摊共享内存(如多个进程共享同一库时,各进程按使用比例分摊该库内存)。USS(Unique Set Size):进程独占的物理内存(不包含任何共享内存),反映进程“真正”占用的内存。
/proc文件系统:底层内存信息
Linux通过/proc虚拟文件系统暴露内核和进程信息,直接读取相关文件可获取最原始的内存数据。
-
常用文件:
/proc/[pid]/status:进程状态信息(包括VmRSS、VmSize)。/proc/[pid]/smaps:详细的内存段占用(按内存区域统计RSS)。/proc/[pid]/maps:内存地址映射(与pmap输出类似)。
-
示例:
cat /proc/[pid]/status | grep VmRSS # 查看进程物理内存占用 cat /proc/[pid]/smaps | grep "Rss" | awk '{sum+=$2} END {print "Total RSS:", sum"KB"}' # 计算进程总RSS
系统级内存监控
free命令:查看系统整体内存使用
free用于展示系统物理内存、交换分区(swap)的使用情况,结合-h参数可显示人类可读格式(GB/MB)。
- 示例:
free -h # 以GB/MB为单位显示内存使用 free -m # 以MB为单位显示,适合脚本处理
- 关键字段:
total:总物理内存。used:已使用内存(包括应用+缓存+缓冲区)。free:完全空闲内存。buff/cache:缓存和缓冲区(可被系统回收,属于“可用内存”)。available:实际可用内存(free+buff/cache-预留内存),比free更准确。
vmstat命令:监控内存活动
vmstat(Virtual Memory Statistics)可实时显示内存交换、页面错误等动态信息,适合分析内存瓶颈。
- 示例:
vmstat -s # 显示内存统计信息(如总内存、空闲内存、交换次数) vmstat 1 # 每秒刷新,关注si(swap in)和so(swap out)是否为0
- 关键指标:
si:从swap分区调入内存的数据量(单位KB/s),若持续大于0,说明内存不足。so:调出到swap分区的数据量(单位KB/s),同上。
命令对比与适用场景
| 命令 | 功能特点 | 适用场景 | 优点 | 缺点 |
|---|---|---|---|---|
ps |
静态查看,基础信息 | 快速查看单个/多个进程内存占用 | 简单、预装系统 | 无实时更新,信息较简略 |
top |
实时动态监控,交互式操作 | 实时监控高内存进程 | 动态刷新、排序灵活 | 输出复杂,无内存细分统计 |
htop |
增强版交互式,树状结构 | 日常监控、进程关系分析 | 界面友好、功能丰富 | 需额外安装 |
pmap |
内存映射分析,段级统计 | 内存泄漏定位、异常内存分配 | 细度高,可分析内存段 | 仅针对单个进程 |
smem |
计算PSS/USS,解决共享内存重复 | 多进程共享内存场景 | 准确反映实际内存占用 | 需安装,输出较复杂 |
/proc |
底层原始数据,可脚本化 | 深度调试、自动化监控 | 数据最原始、灵活 | 需手动解析文件,可读性差 |
free |
系统级内存概览 | 快速检查系统内存是否充足 | 简单直观、预装系统 | 不适用于进程级分析 |
vmstat |
内存活动监控,交换分区统计 | 分析内存瓶颈、swap使用情况 | 动态展示内存活动 | 无进程级信息 |
相关问答FAQs
Q1:如何区分进程的物理内存占用(RSS)和虚拟内存占用(VSZ)?
A:VSZ(Virtual Memory Size)是进程虚拟地址空间的总大小,包括未实际分配的内存(如保留地址空间)、代码段、数据段、共享库等,仅反映进程“理论上”可用的内存范围;RSS(Resident Set Size)是进程实际占用的物理内存(不含swap),是系统真正分配给该进程的内存量,一个进程加载了1GB的共享库,即使未完全使用,VSZ会包含这1GB,但RSS仅反映实际加载到物理内存的部分。
Q2:为什么某个进程的内存占用很高,但系统可用内存(available)却没减少?
A:这通常是因为进程占用的内存大部分被系统作为“缓存/缓冲区”回收,Linux会主动将空闲内存用于缓存文件数据(如buff/cache),当进程需要内存时,系统会优先回收这部分缓存,而不会直接减少available值,可通过free -h查看buff/cache列,若该列数值较大,说明内存被高效利用;若si(swap in)持续大于0,才说明真正内存不足。
原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/17809.html