java 内存泄漏_记一次简单的JAVA内存泄漏分析过程

查看垃圾回收情况并对内存进行转储

  1. 查询JAVA线程
#ps -ef | grep java

#jps

5014cd5b375545e79d84e58aef81183c.png

2.查看垃圾回收总体统计情况

# jstat -gcutil pid

956c9168bc94dcb85c848276ba1d4c5b.png
  • S0:幸存1区当前使用比例
  • S1:幸存2区当前使用比例
  • E:伊甸园区使用比例
  • O:老年代使用比例
  • M:元数据区使用比例
  • CCS:压缩使用比例
  • YGC:年轻代垃圾回收次数
  • FGC:老年代垃圾回收次数
  • FGCT:老年代垃圾回收消耗时间
  • GCT:垃圾回收消耗总时间

3.查看垃圾回收详情

# jstat -gc pid

3da09324977f9605b21eef608cffe429.png
  • S0C:第一个幸存区的大小
  • S1C:第二个幸存区的大小
  • S0U:第一个幸存区的使用大小
  • S1U:第二个幸存区的使用大小
  • EC:伊甸园区的大小
  • EU:伊甸园区的使用大小
  • OC:老年代大小
  • OU:老年代使用大小
  • MC:方法区大小
  • MU:方法区使用大小
  • CCSC:压缩类空间大小
  • CCSU:压缩类空间使用大小
  • YGC:年轻代垃圾回收次数
  • YGCT:年轻代垃圾回收消耗时间
  • FGC:老年代垃圾回收次数
  • FGCT:老年代垃圾回收消耗时间
  • GCT:垃圾回收消耗总时间

4.如果FGC频率过高(老年代垃圾回收过于频繁,存在内存泄漏风险),通过jmap转储堆内存信息。

#jmap -dump:format=b,file=<dumpfile.hprof> <pid> 

a3ff172a5c867a53985bddd59b645085.png

内存分析

dump内存堆栈信息到本地后,通过esclipse 的MAT软件进行内存分析。

6df0d3994907ec663ea615090ccf3c4c.png
该截图仅作为操作步骤参考,数据根据具体情况来分析

Problem Suspect 为疑似存在内存泄漏的分析结果,可根据该结论进行代码排查。

其他常用命令

1.查看GC情况。

#查看内存占用情况
free -m 
free -g

# 查询JAVA线程
ps -ef | grep java
jps
# 把相应进程的老年代大小,老年代使用大小信息采集出来
jstat -gc pid
# 把相应进程的堆栈及GC统计信息打印出来
jstat -gcutil pid

# 获取堆转储文件
jmap -dump:format=b,file=<dumpfile.hprof> <pid>
# dump堆栈信息到本地
sudo sz <dumpfile.hprof> 

#查看文件大小
ls -lh
ll -h

jstat命令参考:

jstat命令查看jvm的GC情况 (以Linux为例)​www.cnblogs.com
4aa1ca0254ee52af377ace3c5edc86fa.png

2.Eclipse MAT内存泄漏分析插件

下载地址:http://www.eclipse.org/mat/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值