JVisualVM使用教程

了解JVisualVM

JVisualVM是一个基于java的综合性能监控和故障排查工具,它用于实时监控和分析 Java 应用程序的运行时性能,包括 CPU 使用率、内存使用情况、线程活动等。JVisualVM 可以帮助开发人员识别和解决性能瓶颈、内存泄漏以及其他运行时问题。

JVisualVM的主要功能

1、实时监控

  • CPU 使用率:显示应用程序的 CPU 消耗情况。
  • 内存使用:监控堆内存的使用情况,包括已分配和正在使用的内存。
  • 线程活动:查看和分析线程的状态和活动情况。

2、性能分析

  • CPU 采样:分析应用程序的 CPU 使用情况,识别性能瓶颈。
  • 内存分析:进行堆转储分析,识别内存泄漏或不合理的内存使用。

3、堆转储分析

  • 捕获堆转储并分析对象的分布、引用链等,以识别内存泄漏和性能问题。

4、线程分析

  • 查看线程的状态和堆栈跟踪,帮助诊断线程相关的性能问题。

5、JMX 监控

  • 支持通过 JMX(Java Management Extensions)监控和管理 Java 应用程序。

下载安装

JDK8及之前的版本,可以直接在JDK的bin目录下找到jvisualvm.exe程序,直接运行即可;JDK11之后的版本需要到官网下载安装

下载地址:VisualVM: Home

解压运行即可

JVisualVM界面功能介绍

在本地IDEA上运行一个JAVA程序,VisualVM就能监控到

概述页:

监控页

线程页:允许用户实时监视Java应用程序的线程信息,包括线程的状态、执行轨迹等,帮助排查死锁、线程阻塞等问题。

采样器:

分析器:分析CPU、内存、sql的性能

JVisualVM 插件安装

如果以上功能都不能满足对性能问题进行分析,当然我们还可以安装JVisualVM的插件来进行分析,比如Visual GC,可以看到垃圾回收的年轻代、老年代的内存变化以及GC的频率,GC的时间等

JVisualVM 远程连接

以阿里云服务器为例

方式一:JMX

1、到maven仓库下载jmx依赖

地址: https://mvnrepository.com/artifact/org.apache.tomcat/tomcat-catalina-jmx-remote

放到 tomcat/lib目录下

2、在tomcat/bin catalina.sh文件中添加如下配置

#开启jmx远程监控
-Dcom.sun.management.jmxremote=true
#公网ip
-Djava.rmi.server.hostname=公网ip
#远程服务端口(自取,和tomcat上端口不冲突就行)
-Dcom.sun.management.jmxremote.port=9001
#本地jmx client提供服务的端口,要和服务端相同
-Dcom.sun.management.jmxremote.rmi.port=9001
#关闭ssl和认证功能
-Dcom.sun.management.jmxremote.ssl=false 
-Dcom.sun.management.jmxremote.authenticate=false

3、进入tomcat的conf目录,修改server.xml文件,添加如下的监听配置

<!-- 远程监控 -->
  <Listener className="org.apache.catalina.mbeans.JmxRemoteLifecycleListener" rmiRegistryPortPlatform="9001" rmiServerPortPlatform="9001" />

4、阿里云安全组添加9001端口

5、重启tomcat

6、VisualVM客户端添加远程连接

右键,Add JMX Connection

至此,我们就成功连上啦

PS:如果想监控一个java程序,我们可以直接在启动命令上加jmx监控参数,参考如下:

nohup java -jar -Dcom.sun.management.jmxremote=true -Djava.rmi.server.hostname=8.134.23.x -Dcom.sun.management.jmxremote.port=9001 -Dcom.sun.management.jmxremote.rmi.port=9001 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false demo3-0.0.1-SNAPSHOT.jar

方式二:jstatd

1、配置jstatd.policy,进入到jdk的安装配置目录/usr/local/java/jdk-17.0.12/conf/security

2、编辑java.policy,加入下面的配置

permission java.security.AllPermission

配置所在位置截图:

3、进入jstatd所在的目录/usr/local/java/jdk-17.0.12/bin,启动jstatd,命令如下,远程主机ip换成自己的

jstatd -J-Djava.security.policy=jstatd.all.policy -J-Djava.rmi.server.hostname=8.134.23.x -J-Djava.rmi.server.logCalls=false

4、查看jstatd端口

5、安全组开放jstatd端口

6、Add jstatd Connection

这篇文章就到这里啦,具体的性能分析,下篇文章会给出具体的例子进行分析。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值