jvm的各种性能检测工具

1: jvm 的性能诊断工具

1.1.:Jstat

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

java 复制代码
jstat -gc pid
jstat -gcutil pid

最终的这些结果命令如下,C 代表capacity,U代表使用情况:

1.2: jmap

这个的全称就是 Memory Map for Java,说白了就是查看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级别

相关推荐
__土块__11 小时前
大厂后端一面模拟:从线程安全到分布式缓存的连环追问
jvm·redis·mysql·spring·java面试·concurrenthashmap·大厂后端
fly spider20 小时前
一文概括 JVM 核心内容
jvm
brahmsjiang20 小时前
Java类加载机制解析:从JVM启动到双亲委派,再到Android的特殊实现
android·java·jvm
cch891820 小时前
C++、Python与汇编语言终极对比
java·开发语言·jvm
zshs00020 小时前
从 HashMap 到基因法:同一套位运算思想,如何从 JVM 走到分布式数据库
jvm·数据库·分布式
彧翎Pro1 天前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm
minji...1 天前
Linux 线程同步与互斥(二) 线程同步,条件变量,pthread_cond_init/wait/signal/broadcast
linux·运维·开发语言·jvm·数据结构·c++
woai33641 天前
JVM学习-基础篇-常见引用
jvm·学习
それども1 天前
理解JVM参数 Xss 线程的栈大小
jvm
玛卡巴卡ldf1 天前
【Springboot6】内存泄漏OOM、VisualVM、Arthas、Prometheus Grafana监控、垃圾回收
java·jvm·springboot