用ps命令查看进程的内存

ps命令是Linux下常见的查看进程状况的程序,它有几个字段可以用来查看进程内存使用情况:sz,rss,vsz。分别说明如下:

  • sz:进程映像所占用的物理页面数量,也就是以物理页面为单位表示的虚拟内存大小;
  • rss:进程当前所占用的物理内存大小,单位为kB;
  • vsz:进程的虚拟内存大小,单位为kB,它等于sz乘于物理页面大小(x86平台通常为4kB)。

 

假如我要查看程序a.out的内存使用情况,操作如下:



$ ./a.out &[1] 10069 $ ps -O sz,rsz,vszPID SZ RSS VSZ S TTY TIME COMMAND 6793 1545 3648 6180 S pts/2 00:00:00 /bin/bash10069 404 304 1616 S pts/2 00:00:00 ./a.out10070 626 876 2504 R pts/2 00:00:00 ps -O sz,rss,vsz



上面ps命令的输出的第3行就是./a.out自行后的相关情况。我们可以看出,它的虚拟 内存大小为1616kB,当前占用的物理内存为304kB(其它数据在磁盘上或交换分区),虚 拟内存占用404个物理页面。由于我的机器的物理页面大小为4kB,可以验证404 x 4kB等于1616kB。

 

用/proc文件系统查看进程的内存使用情况

ps命令的输出关于内存的情况不是很详细,尤其是进程所使用的内存中有很大一部分是共享库函数使用的,因此通过ps命令的输出看不到进程自己使用了多少内存。为了查看更详细的信息,可以借助于/proc文件系统。这个文件系统并存在于磁盘上,但是可以象操作其它普通文件一样操作它。它是Linux提供给用户查看进程相关信息的接口。在/proc下有2个文件和进程内存有关:/proc/<pid>/status和/proc/<pid>/smaps。

通过/proc/<pid>/status可以查看进程的内存使用情况,包括虚拟内存大小(VmSize),物理内存大小(VmRSS),数据段大小(VmData),栈的大小(VmStk),代码段的大小(VmExe),共享库的代码段大小(VmLib)等等。



$ cat /proc/10069/statusName: a.outState: S (sleeping)Tgid: 10069Pid: 10069PPid: 6793TracerPid: 0Uid: 1001 1001 1001 1001Gid: 1001 1001 1001 1001FDSize: 256Groups: 1000 1001 VmPeak: 1692 kBVmSize: 1616 kBVmLck: 0 kBVmHWM: 304 kBVmRSS: 304 kBVmData: 28 kBVmStk: 88 kBVmExe: 4 kBVmLib: 1464 kBVmPTE: 20 kBThreads: 1SigQ: 0/16382SigPnd: 0000000000000000ShdPnd: 0000000000000000SigBlk: 0000000000000000SigIgn: 0000000000000000SigCgt: 0000000000000000CapInh: 0000000000000000CapPrm: 0000000000000000CapEff: 0000000000000000CapBnd: ffffffffffffffffCpus_allowed: fCpus_allowed_list: 0-3Mems_allowed: 1Mems_allowed_list: 0voluntary_ctxt_switches: 1nonvoluntary_ctxt_switches: 1



 

注意,VmData,VmStk,VmExe和VmLib之和并不等于VmSize。这是因为共享库函数的数据段没有计算进去(VmData仅包含a.out程序的数据段,不包括共享库函数的数据段,也不包括通过mmap映射的区域。VmLib仅包括共享库的代码段,不包括共享库的数据段)。

通过/proc/<pid>/smaps可以查看进程整个虚拟地址空间的映射情况,它的输出从低地址到高地址按顺序输出每一个映射区域的相关信息,如下所示:



$ cat /proc/10069/smaps00110000-00263000 r-xp 00000000 08:07 128311 /lib/tls/i686/cmov/libc-2.11.1.soSize: 1356 kBRss: 148 kBPss: 8 kBShared_Clean: 148 kBShared_Dirty: 0 kBPrivate_Clean: 0 kBPrivate_Dirty: 0 kBReferenced: 148 kBSwap: 0 kBKernelPageSize: 4 kBMMUPageSize: 4 kB............bfd7f000-bfd94000 rw-p 00000000 00:00 0 [stack]Size: 88 kBRss: 8 kBPss: 8 kBShared_Clean: 0 kBShared_Dirty: 0 kBPrivate_Clean: 0 kBPrivate_Dirty: 8 kBReferenced: 8 kBSwap: 0 kBKernelPageSize: 4 kBMMUPageSize: 4 kB



注意:rwxp中,p表示私有映射(采用Copy-On-Write技术)。 Size字段就是该区域的大小。


转载于:https://blog.51cto.com/chengying/971289