jvm常用监控工具详细介绍 下

使用jvisualvm

第一种在jdk安装目录的bin下

第二种 win+r 输出jvisualvm 也可直接打开

打开->导入->文件类型选择dump->点击你的dump文件

案例分析

jvm常用监控工具详细介绍 下_第1张图片

创建list集合 存放user对象

死循环创建对象 对象创建在堆 直至内存沾满 爆出内存溢出

运行设置vm 参数

 

jvm常用监控工具详细介绍 下_第2张图片

对内存溢出进行分析

jvm常用监控工具详细介绍 下_第3张图片

 

jvm常用监控工具详细介绍 下_第4张图片

可以看到红色的实例数,点击进去

 

jvm常用监控工具详细介绍 下_第5张图片

 

可以看出创建了很多实例,然后去找代码,解决

 

死锁检测

第一种

jvm常用监控工具详细介绍 下_第6张图片

 

 

第二种 jconsole

jvm常用监控工具详细介绍 下_第7张图片

 

jvm常用监控工具详细介绍 下_第8张图片

 

第三种

jstack pid

jvm常用监控工具详细介绍 下_第9张图片

 

 

远程连接jvisualvm

jconsole也可以远程链接

tomcat的JMX配置

JAVA_OPTS=-Dcom.sun.management.jmxremote.port=8999 

-Dcom.sun.management.jmxremote.ssl=false 

-Dcom.sun.management.jmxremote.authenticate=false

jvisualvm远程连接服务需要在远程服务器上配置host(连接ip 主机名),并且要关闭防火墙

 

 

 

 

jstack找出占用cpu最高的堆栈信息

生产问题分析

1,使用命令top -p ,显示你的java进程的内存情况,pid是你的java进程号,比如4977

2,按H,获取每个线程的内存情况

3,找到内存和cpu占用最高的线程tid,比如4977

4,转为十六进制得到 0x1371 ,此为线程id的十六进制表示

5,执行 jstack 4977|grep -A 10 1371,得到线程堆栈信息中1371这个线程所在行的后面10行

6,查看对应的堆栈信息找出可能存在问题的代码

你可能感兴趣的:(jvm)