jvm的各种性能检测工具

1: jvm 的性能诊断工具

1.1.:Jstat
这个的全称是JVM Statistics Monitoring Tool,说白了就是统计jvm的各种指标的,我们这边主要关注内存使用指标,一般我们后面要跟上pid的进程

jstat -gc pid
jstat -gcutil pid

最终的这些结果命令如下,C 代表capacity,U代表使用情况:
在这里插入图片描述
1.2: jmap
这个的全称就是 Memory Map for Java,说白了就是查看java 堆内存的使用情况,主要查看java 堆内存里面的各种对象的个数和大小,使用方式如下所示:

jmap -dump:format=b,file=heapdump.hprof <pid>
jmap -histo <pid>

第一个命令经常生成文件之后还是要借助工具比如JProfiler,VisualVM和Eclipse MAT
第二个命令就是看这个pid 对应的对象的个数和大小

1.3: jstack
这个说白了就是看进程中调用的各种栈,对于程序hung住排查调用的各种栈很有帮助,使用方法就是 jstack

1.4: jinfo
可以输出并修改运行时的java 进程的opts。用处比较简单,就是能输出并修改运行时的java进程的运行参数。用法是jinfo -opt pid 如:查看2788的MaxPerm大小可以用 jinfo -flag MaxPermSize 2788。

二:jmap,jstat 排查过程,
https://maimai.cn/article/detail?fid=1749959489&efid=Q9mRBrC0YqvOahq4DBJzBA

2.1: 首先查看对应的堆内存使用的各种情况,堆内存溢出
2.2: 使用jmap 把file 搞出来,发现了大量的对象是ConcutrentHashMap
2.3: 继续排查发现是并发导致queryId 被改动了,把queryId 放在对应的operation 级别,不放在session级别

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值