通过visualVM远程监控java进程

1. VisualVM 简介及功能介绍

VisualVM 是一个功能强大的工具,用于监视、分析、配置和调试 Java 应用程序的运行状态。它提供了丰富的功能来帮助开发者和运维人员理解和优化 Java 应用程序的性能。VisualVM 集成了多种 JDK 工具,并通过直观的 GUI 界面提供对 Java 虚拟机(JVM)的深入分析, 可以连接到本地和远程的 JVM 实例,并提供有关应用程序运行时状态、内存使用情况、线程活动等的详细信息。

2. Visual功能

2.1 监视和管理 JVM:

  • 概览:提供 Java 应用程序的基本信息,包括 JVM 参数、类加载器、系统属性等。
  • 监视:实时监视 CPU、内存、线程和类加载器的使用情况,帮助识别性能瓶颈。

2.2 内存分析:

  • 堆转储:生成和分析堆转储,帮助检测内存泄漏和查看对象的分配情况。
  • GC 活动:查看垃圾收集活动的详细信息,帮助优化垃圾收集器的性能。

2.3 线程分析:

  • 线程转储:捕获线程转储,查看线程的状态和调用堆栈,帮助解决线程争用和死锁问题。
  • 线程监视:实时监视线程的活动,了解线程的执行情况和状态变化。

2.4 CPU 分析:

  • 性能分析:使用采样和探查器分析应用程序的 CPU 使用情况,识别性能瓶颈和高耗时的方法。
  • 热点分析:确定应用程序中最耗费 CPU 资源的部分,优化代码性能。

2.5 远程监控:

  • JMX 集成:通过 JMX(Java Management Extensions)连接和监视远程 JVM 实例,查看和管理远程应用程序的运行时状态。
  • 远程诊断:对远程应用程序进行性能分析和诊断,无需在目标服务器上安装额外的软件。

插件支持:

  • 可扩展性:支持通过插件扩展功能,用户可以根据需要安装和配置各种插件,以增加额外的分析工具和功能。

3. VisualVM使用及配置

3.1 下载对应的visualVM版本

进入官网下载对应的visualVM版本,并解压到本地,可以在bin目录下找到运营的exe文件。

3.2 远程启动启用 JMX(Java Management Extensions)远程管理

java -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=8777 -Dcom.sun.management.jmxremote.local.only=true -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.rmi.port=8777 -Djava.rmi.server.hostname=demo -jar demo.jar
  1. -Dcom.sun.management.jmxremote
    启用 JMX 远程管理和监控功能。这是一个启用 JMX 远程连接的开关。

  2. -Dcom.sun.management.jmxremote.port=8777
    指定 JMX 远程连接使用的端口号。这里设置为 8777。

  3. -Dcom.sun.management.jmxremote.local.only=true
    限制 JMX 连接仅限于本地连接,即只允许从同一台机器进行 JMX 连接。这是一个安全设置,防止远程连接。

  4. -Dcom.sun.management.jmxremote.authenticate=false
    禁用 JMX 连接的身份验证。默认情况下,JMX 连接是需要身份验证的,禁用身份验证会降低安全性,不建议在生产环境中使用。

  5. -Dcom.sun.management.jmxremote.ssl=false
    禁用 JMX 连接的 SSL 加密。默认情况下,JMX 连接是通过 SSL 加密的,禁用 SSL 会降低安全性,不建议在生产环境中使用。

  6. -Dcom.sun.management.jmxremote.rmi.port=8777
    指定 RMI(Remote Method Invocation)连接使用的端口号。这里设置为 8777。这个端口用于 RMI 远程对象的连接。

  7. -Djava.rmi.server.hostname=demo
    设置 RMI 服务器的主机名为 demo。这指定了远程客户端在连接时应使用的主机名。

  8. -jar demo.jar
    指定要运行的 Java 应用程序的 JAR 文件,这里是 demo.jar。-jar 选项告诉 Java 虚拟机从指定的 JAR 文件中启动应用程序。

安全性提醒

  • 本地连接:-Dcom.sun.management.jmxremote.local.only=true 限制为本地连接,是一种安全措施,防止远程连接。
  • 禁用身份验证和 SSL:-Dcom.sun.management.jmxremote.authenticate=false 和 -Dcom.sun.management.jmxremote.ssl=false 禁用身份验证和 SSL 加密,会降低安全性,通常只在开发或测试环境中使用。在生产环境中应启用身份验证和 SSL,以确保安全。

这些参数配置允许您在开发或测试过程中方便地使用 JMX 进行监控和管理,但在生产环境中使用时,请确保启用必要的安全措施。

3.3 配置jstatd并启动

3.3.1 权限配置文件jstatd.all.policy

grant codebase "file:${java.home}/../lib/tools.jar" {
        permission java.security.AllPermission;
};

3.3.2 启动jstatd服务

jstatd -J-Djava.security.policy=./jstatd.all.policy -J-Djava.rmi.server.hostname=demo &

如果要开启日志,可以加上参数:
-J-Djava.rmi.server.logCalls=true
注意:RMI服务器主机名应和JMX远程管理服务保持一致。

3.3.3 开放端口访问权限

启动后可以使用以下命令检查是否启动完成;
ps -aux | grep jstatd – 查看jstatd进程服务
netstat -antup|grep jstatd --查看启动的端口
在这里插入图片描述
通过上图发现,除了jstatd的默认端口1099外,还有一个随机端口号36629,这两个端口我们都需要在防火墙或者安全组中开启访问权限。

3.4 启动visualVM

启动visualVM,并添加以下两个连接:
在这里插入图片描述

4. 使用 VisualVM 的场景

  • 性能调优:通过详细的性能分析工具,识别并优化应用程序的性能瓶颈。
  • 内存管理:分析堆转储,检测内存泄漏,优化内存使用。
  • 线程诊断:捕获和分析线程转储,解决线程争用和死锁问题。
  • 实时监控:实时监视应用程序的运行状态,及时发现和解决性能问题。
  • 远程管理:通过 JMX 和其他远程监控功能,管理和监视远程部署的应用程序。

5. 总结

VisualVM 是一个全面且易用的工具,适用于 Java 应用程序的性能监控和分析。它结合了多种分析工具和功能,为开发者和运维人员提供了一个强大的平台,以确保 Java 应用程序的高效运行和稳定性。

  • 12
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Java VisualVM是一种用于分析Java应用程序的工具,可以使用它来分析dump文件。以下是使用Java VisualVM分析dump文件的步骤: 1. 打开Java VisualVM并选择“File”菜单中的“Load”选项。 2. 选择要分析的dump文件并加载它。 3. 在左侧的“Applications”窗口中选择要分析的Java应用程序。 4. 在右侧的“Monitor”窗口中选择要分析的线程或进程,并查看其性能指标和堆栈跟踪信息。 5. 使用Java VisualVM提供的其他工具和插件来进一步分析和优化Java应用程序的性能。 总之,Java VisualVM是一种非常有用的工具,可以帮助开发人员诊断和解决Java应用程序的性能问题。 ### 回答2: Java VisualVM是一个Java虚拟机监视和分析工具。它提供了实时的应用程序性能监控,以及基于某些特定平台的内存和线程分析。使用Java VisualVM可以分析非常详细的诊断信息,它可以非常轻松地获取一个Java应用程序运行时的进程快照,即dump文件。在获取到dump文件后,我们可以通过Java VisualVM对dump文件进行分析,以更深入地了解应用程序的性能状况,从而提高程序的性能。下面我们来具体说明如何使用Java VisualVM分析dump文件。 在使用Java VisualVM分析dump文件之前,首先需要下载和安装Java VisualVMJava VisualVM提供了以下两种方式来分析dump文件: 1.打开本地应用程序 打开Java VisualVM后,从菜单栏中点击File -> Load 即可打开本地应用程序,并可以在Applications选项卡中查看正在运行的Java进程。选取需要分析的进程,然后点击Snapshot按钮,即可生成dump文件。 2.分析远程应用程序 Java VisualVM还提供了通过JMX连接到远程应用程序获取dump文件的方式。选择File -> Add JMX Connection选项,并输入连接的IP地址和端口号。成功连接后,点击Applications选项卡,选择远程应用程序,然后点击Snapshot按钮即可生成dump文件。 在得到dump文件之后,我们可以通过Java VisualVM来进行性能分析。首先我们需要打开dump文件,选择File -> Load Snapshot,选择目标dump文件。在界面的左侧,我们可以看到以下五个选项卡: 1. Overview 用于查看堆内存和线程状况的概览。 2. Monitor 用于实时监控Java应用程序的性能和资源使用情况,如CPU、内存、线程等。 3. Heap Dump 用于查看内存快照中的详细信息,帮助找出内存泄漏和对象占用情况。 4. Threads 用于查看各个线程的状态和历史记录,并对线程进行诊断和采样。 5. Samples 用于对应用程序的性能瓶颈进行采样和分析,查找性能瓶颈和优化应用程序。 通过以上选项卡,我们可以对应用程序进行更加深入的性能分析,找出应用程序的性能瓶颈,帮助我们更好地优化应用程序的性能。 ### 回答3: Java VisualVMJava 官方提供的一个性能分析工具,它可以通过连接远程或本地的 JVM 进程,收集各种性能相关的数据,包括堆内存、CPU、线程、GC 等。同时,Java VisualVM 还能够生成 Heap Dump 文件,用于分析内存泄露等问题。本文主要介绍如何使用 Java VisualVM 分析 Heap Dump 文件。 一、导出 Heap Dump 文件 在 Java VisualVM 中,我们可以在“Applications” 中找到正在运行的 Java 应用程序,右键点击应用程序进程并选择“Heap Dump”即可生成 Heap Dump 文件,存放在本地文件系统中。该文件包含了 JVM 进程的整个内存快照,用于分析内存泄露、对象引用等问题。 二、分析 Heap Dump 文件 1. 打开 Heap Dump 文件 将 Heap Dump 文件导入到 Java VisualVM 中,可以通过“File”-”Load”-”Heap Dump”来打开。 2. 了解 Heap Dump 概要信息 通过查看 Heap Dump 的概要信息,可以了解到该应用程序的总内存使用量、对象个数、堆内存各区域的使用情况等。 3. 查看对象实例 在“Classes”标签页中,我们可以查看 Heap Dump 文件中所有的类,其中包含每个对象的实例数、占用内存大小等信息。可以通过该信息找到占用内存较大的对象,进一步分析其使用情况。 4. 分析对象引用 通过“References”标签页,我们可以查看各个对象之间的引用关系。可以通过该信息找到内存泄露的对象引用,找到引用该对象的对象,或使用MAT等工具分析该对象的引用链路,定位到引用根源。 5. 分析堆内存分布 通过“Heap Dump”标签页,我们可以查看堆内存分布情况。可以查看到堆内存各区域的内存大小及使用情况,从而了解内存的占用情况。 三、结论 本文介绍了如何使用 Java VisualVM 分析 Heap Dump 文件,通过了解对象实例、对象引用、堆内存分布等信息,找到内存泄露的对象,并定位到引用根源,进一步优化应用程序,提高其性能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值