查看垃圾回收情况并对内存进行转储
- 查询JAVA线程
#ps -ef | grep java
或
#jps
2.查看垃圾回收总体统计情况
# jstat -gcutil pid
- S0:幸存1区当前使用比例
- S1:幸存2区当前使用比例
- E:伊甸园区使用比例
- O:老年代使用比例
- M:元数据区使用比例
- CCS:压缩使用比例
- YGC:年轻代垃圾回收次数
- FGC:老年代垃圾回收次数
- FGCT:老年代垃圾回收消耗时间
- GCT:垃圾回收消耗总时间
3.查看垃圾回收详情
# jstat -gc pid
- 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>
内存分析
dump内存堆栈信息到本地后,通过esclipse 的MAT软件进行内存分析。
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.com2.Eclipse MAT内存泄漏分析插件
下载地址:http://www.eclipse.org/mat/