linux下使用命令行辅助定位内存泄漏问题

前言

最近自己正在做的一款产品,因内存泄漏经常出现重启或者是功能不正常的问题。为了解决这个问题,这里记录下目前所掌握到的使用命令行定位内存泄漏的一些措施。

有点我们需要清楚,使用linux的命令行最多是帮我们定位到产生泄漏的进程,而并不能直接帮我们找出内存泄漏的具体原因,所以当定位到具体进程后,还需自己去参考别的博客采取一些手段去进一步定位泄漏原因。

注⚠️:我后面所说的内存一般就是物理内存,如果是虚拟内存我会进行说明。

一、free命令:

free命令主要用于查看设备的内存使用情况,主要用于确定设备是否存在内存泄漏。

命令

free
或者
cat /proc/meminfo

请添加图片描述

内容解释

内容解释
total内存总量
used已使用的内存
free空闲内存
shared共享内存
buff/cachebuffer(可释放):存放要写到disk(块设备)中的数据 / cache(可释放):存放从disk中读取的数据。
available可用内存 available
我们可以通过在设备启动和运行一段时间后,分别使用free命令查看已使用内存used的大小并进行对比,如果运行一段时间后used有很明显的增大那很有可能是存在内存泄漏。

其它

  • 关于buff/cache的具体区别大家可以查看:
    链接: buffer和cache怎么让你们解释的那么难理解?.
  • available到底是什么意思?
    avaliable是新的free命令中增加的,它的大概计算方式是:
    available = free + cache + buff
    但是实际上上述等式并不一定相等,cache/buff虽然都是可回收内存(当内存告急的时候,内核会回收这部分的内容进行使用)但是实际上回收的时候并非所有的cache都能够被回收。
    参考链接:链接: linux free 命令下free/available区别.

二、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查看当前进程的物理内存是否相比较于刚启动时,明显增大。

  • 2
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
定位Linux命令行中的内存泄漏和CPU过高的线程和具体代码,您可以使用以下工具: 1. top: top 命令可以实时显示系统的 CPU 使用率、内存使用率、进程数量等信息,并按 CPU 使用率排序。您可以使用 top 命令来查找 CPU 占用过高的进程,并找出其进程 ID。 2. ps: ps 命令可以显示系统中正在运行的进程的详细信息。使用 ps 命令时,您可以通过 -eo 参数来选择需要显示的进程信息,例如进程 ID、CPU 占用率、内存使用量等。您可以使用 ps 命令来查找特定进程的详细信息,例如其线程 ID、进程状态等。 3. pmap: pmap 命令可以显示进程的内存映射。使用 pmap 命令时,您可以通过 -x 参数来显示详细信息,例如内存占用量、内存映射地址等。您可以使用 pmap 命令来查找进程的内存占用情况,以判断是否存在内存泄漏。 4. strace: strace 命令可以跟踪进程执行的系统调用,以及调用的结果和参数。使用 strace 命令时,您可以通过 -p 参数来指定需要跟踪的进程 ID。您可以使用 strace 命令来查找进程执行的具体代码,以判断是否存在 CPU 占用过高的问题。 5. perf: perf 命令可以提供系统和进程的性能分析信息。使用 perf 命令时,您可以通过 record 子命令来记录进程执行的函数调用栈信息。然后,使用 report 子命令来查看记录的性能信息。您可以使用 perf 命令来查找进程执行的具体代码,并进行性能分析。 总之,要定位Linux命令行中的内存泄漏和CPU过高的线程和具体代码,您需要综合使用以上工具来进行系统和进程的监控、跟踪、性能分析等工作,以便找出问题所在。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值