通过visualVM远程监控java进程

2024-06-22 20:28

本文主要是介绍通过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 应用程序的高效运行和稳定性。

这篇关于通过visualVM远程监控java进程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1085322

相关文章

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

基于SpringBoot+Mybatis实现Mysql分表

《基于SpringBoot+Mybatis实现Mysql分表》这篇文章主要为大家详细介绍了基于SpringBoot+Mybatis实现Mysql分表的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录基本思路定义注解创建ThreadLocal创建拦截器业务处理基本思路1.根据创建时间字段按年进

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J