前言
最近自己正在做的一款产品,因内存泄漏经常出现重启或者是功能不正常的问题。为了解决这个问题,这里记录下目前所掌握到的使用命令行定位内存泄漏的一些措施。
有点我们需要清楚,使用linux的命令行最多是帮我们定位到产生泄漏的进程,而并不能直接帮我们找出内存泄漏的具体原因,所以当定位到具体进程后,还需自己去参考别的博客采取一些手段去进一步定位泄漏原因。
注??:我后面所说的内存一般就是物理内存,如果是虚拟内存我会进行说明。
一、free命令:
free命令主要用于查看设备的内存使用情况,主要用于确定设备是否存在内存泄漏。
命令
free
或者
cat /proc/meminfo
内容解释
内容 | 解释 |
---|
total | 内存总量 | used | 已使用的内存 | free | 空闲内存 | shared | 共享内存 | buff/cache | buffer(可释放):存放要写到disk(块设备)中的数据 / cache(可释放):存放从disk中读取的数据。 | available | 可用内存 available |
我们可以通过在设备启动和运行一段时间后,分别使用free命令查看已使用内存used的大小并进行对比,如果运行一段时间后used有很明显的增大那很有可能是存在内存泄漏。
其它
二、top命令
top命令是实时动态地查看系统的整体运行情况,一般我查cpu的占用率的时候会用到这个,其它的时候我用的很少。
命令
top
这个命令返回结果的格式可以自己制定,我这里是展现的我们的设备上返回的结果,该命令的具体使用大家可以参考标题“其它”里面的内容。
我这里提一个点就是vsz,起初我以为看进程的内存使用情况就看vsz就行了,后面发现这样是不正确的。 vsz(virtual memory size):It includes all memory that the process can access, including memory that is swapped out, memory that is allocated, but not used, and memory that is from shared libraries. 它包括进程可以访问的所有内存,包括被换出的内存,已分配但未使用的内存以及来自共享库的内存。
其它
具体内容参考:
三. cat /proc/$pid/status
查看具体进程的状态,包括该进程的内存使用情况。 其中pid是进程号,你可以先通过ps命令查看应用程序的pid(例如是702),然后通过 cat /proc/702/status 来查看该进程的内存使用情况。
命令
cat /proc/702/status
(这里我要查看的是pid = 702的进程)
内容解释
这里我只说一些和内存相关的吧。
内容 | 解释 |
---|
VmPeak | 代表当前进程运行过程中占用内存的峰值. | VmSize | 代表进程现在正在占用的内存.(虚拟内存) | VmLck | 代表进程已经锁住的物理内存的大小.锁住的物理内存不能交换到硬盘. | VmHWM | 是程序得到分配到物理内存的峰值… | VmRSS | 是程序现在使用的物理内存. | VmData | 表示进程数据段的大小. | VmStk | 表示进程堆栈段的大小. | VmExe | 表示进程代码的大小. | VmExe | 表示进程代码的大小. | VmLib | 表示进程所使用LIB库的大小. | VmPTE | 占用的页表的大小. | VmSwap | 进程占用Swap的大小… |
这里主要看VmRSS,它代表着当前正在使用的物理内存的大小,一般该进程存在内存泄漏的话,在启动时到运行一段时间后,该值会明显急剧增大。
总结
1.通过free命令确定设备是否存在泄漏 2.通过ps命令获取要查找的应用进程的pid 3.通过cat /proc/$pid/status 中的VmRSS查看当前进程的物理内存是否相比较于刚启动时,明显增大。
|