JVM内存监控及分析方法

1、使用jstat命令查看堆内存分布

启动一个java应用
在这里插入图片描述
jstat -gcutil 1122 1000
1122是进程号,1000表示1秒打印一次
在这里插入图片描述
S0:幸存0区当前使用比例
S1:幸存1区当前使用比例
E:年轻代使用比例
O:老年代使用比例
M:元空间使用比例
CCS:压缩使用比例
YGC:年轻代垃圾回收次数
FGC:老年代垃圾回收次数
FGCT:老年代垃圾回收消耗时间
GCT:垃圾回收消耗总时间

jstat -gc 1122 1000
在这里插入图片描述
S0C:幸存0区的大小
S1C:幸存1区的大小
S0U:幸存0区的使用大小
S1U:幸存1区的使用大小
EC:年轻代的大小
EU:年轻代的使用大小
OC:老年代的大小
OU:老年代的使用大小
MC:元空间的大小
MU:元空间的使用大小
CCSC:压缩类空间的大小
CCSU:压缩类空间使用的大小
YGC:年轻代垃圾回收次数
YGCT:年轻代垃圾回收消耗时间
FGC:老年代垃圾回收次数
FGCT:老年代垃圾回收消耗时间
GCT:垃圾回收消耗总时间
单位:字节

2、使用jcmd统计堆中的对象信息

jcmd 1280 GC.class_histogram
在这里插入图片描述
从左到右依次是行号、对象个数、对象大小(单位:字节)、类名

jcmd 1280 GC.run
在这里插入图片描述
手动执行GC,可以观察GC前后新生代和老年代空间回收情况以及对象回收情况从而赋值分析内存泄露问题。

3、监控堆外内存

在这里插入图片描述
引用自https://www.modb.pro/db/516032

启动命令中增加-XX:NativeMemoryTracking=summary
如过提示Java HotSpot™ 64-Bit Server VM warning: Native Memory Tracking did not setup properly, using wrong launcher?

在这里插入图片描述
可能原因是-XX:NativeMemoryTracking=summary没有放到-jar前面
在这里插入图片描述

jcmd 1405 VM.native_memory统计内存占用
在这里插入图片描述
reserved是预留内存,committed是使用的内存。
Java Heap:堆内存占用
Class:元空间内存占用
Thread:线程堆栈内存占用,每个线程默认1M左右
Code:JIT产生的汇编指令所占的空间
GC:用于GC的内存资源
Symbol:符号内存占用,如常量池

native memory(committed)和物理内存(RSS)统计信息不一致,可以通过增加-XX:+AlwaysPreTouch解决。

4、将GC和dump信息输出到文件获取长时间监控数据

nohup java -jar -Djava.net.preferIPv4Stack=true -verbose:gc -Xloggc:/opt/project/employeemgmt/gc.log -XX:+UseG1GC -XX:+PrintGCTimeStamps -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/project/employeemgmt /opt/project/employeemgmt/springboot-03-web-0.0.1-SNAPSHOT.jar &
在这里插入图片描述
查看GC日志
在这里插入图片描述
将Xmx设置小一点触发dump
在这里插入图片描述
输出dump日志
在这里插入图片描述

  • 13
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值