当前位置:网站首页 > 技术博客 > 正文

监控jvm工具



概念: jconsole是jdk自带的一款图形化监控和管理工具。可用于查看java程序运行过程中的内存、线程、类等重要信息。jconsole可直接连接本地java程序,也可远程连接运行中的java程序

一、JConsole远程连接原理

JConsole使用JMX协议与RMI协议远程监控或调用Java程序,大体思路是,连接时,JConsole客户端通过JMX连接服务端,连接成功后再次使用RMI重新调用服务端接口,两次”握手“后才能成功连接客户端与服务端。而在我们的项目中,后端Java服务是通过docker容器的方式部署于宿主机当中的,这就要求docker容器的启动配置需要额外多做一些调整。

二、JConsole远程连接服务端配置(容器启动使用docker-compose)

1.数据文件挂载- /jdk-management:/usr/local/openjdk-17/conf/management服务端启动需要配置远程连接的密码文件(不添加会启动报错)

- jmxremote.access 访问权限配置

- jmxremote.password 访问密码配置

2.jvm启动参数及端口映射

由于JConsole使用两次”握手“实现连接,因此连接通信过程中需要配置可让客户端直接连接的真实ip。

其中

”-Dcom.sun.management.jmxremote"“启动jmx服务,

“-Djava.rmi.server.hostname”配置宿主机真实ip(客户端可直接连接),

”-Dcom.sun.management.jmxremote.port“ 和

”-Dcom.sun.management.jmxremote.rmi.port“设置为同一个端口开放,默认不开启用户验证”

-Dcom.sun.management.jmxremote.authenticate=false“和不开启ssl隧道

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

三、客户端连接使用”-Djava.rmi.server.hostname“配置的真实ip加端口访问,使用jmxremote.password文件中配置的账号密码登录即可。

四、查看各项指标

查看JVM中的基础信息概要,主要有线程、GC、内存、以及启动参数等基础信息

查看和管理 对象,用于监控和管理应用程序的各个组件;

可查看堆内存、线程、类及CPU的基本占用情况

查看JVM运行内存详细占用图

查看JVM运行线程详细占用图,其中可查看线程调用栈

查看JVM类加载折线图

  • 上一篇: jvm调优工具及使用
  • 下一篇: udp编程实例
  • 版权声明


    相关文章:

  • jvm调优工具及使用2025-07-24 09:30:01
  • libxml xpath2025-07-24 09:30:01
  • 线程同步原理2025-07-24 09:30:01
  • 信捷编程软件指令详解2025-07-24 09:30:01
  • se2025-07-24 09:30:01
  • udp编程实例2025-07-24 09:30:01
  • rtt算法2025-07-24 09:30:01
  • jdbc数据库连接池参数2025-07-24 09:30:01
  • c++类中构造函数2025-07-24 09:30:01
  • 公式编辑器破解方法2025-07-24 09:30:01