MAT工具分析应用内存泄漏以及定位问题代码

一、开发环境:

linux 3.10.0-327.el7.x86_64

weblgoic:10.3.6

应用环境JDK版本:java version "1.6.0_45"

本地主机JDK版本:java version "1.8.0_211"

MAT版本:Eclipse Memory Analyzer Version 1.8.0

注:MAT1.8需要1.7及以上版本JDK。

二、内存泄漏分析过程以及代码定位

1、通过主机内存监控,发现主机内存在不断增加,重启后依旧会出现同样的问题。

MAT工具分析应用内存泄漏以及定位问题代码_第1张图片

2、查看JVM监控,发现Old Gen内存使用使用率在不断上升,可以看到在GC时段存在内存回收,但是总体趋势上升。

MAT工具分析应用内存泄漏以及定位问题代码_第2张图片

3、GC时间和次数也在不断上升

MAT工具分析应用内存泄漏以及定位问题代码_第3张图片

出现这种情况,一般都是出现了内存泄漏,这种泄漏情况也是比较难判断。

4、登录主机,查看各存活类名、对象数量和对象占用内存大小:

# jmap -histo:live 4762 | head -20

MAT工具分析应用内存泄漏以及定位问题代码_第4张图片

该com.xxxx.rmw.model.rmclass.pojo.ResClassIndexObj对象占用内存如此多,很有可能与该代码有关。

5、立马做了一个线程Dump

# jmap -dump:format=b,file=476220190829.bin 4762

使用MAT工具打开获得如下分析结果:

MAT工具分析应用内存泄漏以及定位问题代码_第5张图片

点击"LeakSuspects".

MAT工具分析应用内存泄漏以及定位问题代码_第6张图片

此处给出了3个可疑问题。

com.xxxx.common.util.ResDelagateObj是开发商的代码

MAT工具分析应用内存泄漏以及定位问题代码_第7张图片

点击"Details >"

找到‏‎‬‫‍‮‍‮‎‍⁠‌‪‏‎‬‫‍‮‍‮‎‍⁠‌‪"Shortest Paths To the Accumulation Point‫‬‌‏"​‎‍‎‮‫‬‌‏‫​​‎‍‎‮‏‎‬‫‍‮‍‮‎‍⁠‌‪‫‬‌‏‫​​‎‍‎‮

MAT工具分析应用内存泄漏以及定位问题代码_第8张图片

蓝色部分便是工具分析出来可能存在问题部分,点击蓝色部分,选择Java Basics > Thread DetailsMAT工具分析应用内存泄漏以及定位问题代码_第9张图片

这里我们可以看到详细的线程堆栈信息:

MAT工具分析应用内存泄漏以及定位问题代码_第10张图片

在之前的界面,点击Java Basics > Thread Overview and Stacks

MAT工具分析应用内存泄漏以及定位问题代码_第11张图片

展开后,这里我们可以看到问题对象有关的代码调用。

MAT工具分析应用内存泄漏以及定位问题代码_第12张图片

记住这个

at com.xxxx.rga.querymaintain.services.QueryMaintainService.executeQueryByTransSql

接着回到线程堆栈中我们找到有关的代码信息:

MAT工具分析应用内存泄漏以及定位问题代码_第13张图片

这里引起内存泄漏的调用代码。

 

你可能感兴趣的:(weblogic)