在本地windows用jConsole jmc jvisualvm监控图形客户端 连接远程服务器java程序jmx监控服务。解决jmx无法连接问题。jvm监控、性能调优工具

本文主要是介绍在本地windows用jConsole jmc jvisualvm监控图形客户端 连接远程服务器java程序jmx监控服务。解决jmx无法连接问题。jvm监控、性能调优工具,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

环境

  • 云服务器 系统:centos7
  • 系统防火墙 关闭,云服务器安全组 开放 所有tcp端口 ( 如果没有足够的端口权限会连接失败,最后会介绍 )
  • openjdk 1.8

1 随便创建了个可以运行的java程序 打包成jar包 springboot_test-0.0.1-SNAPSHOT.jar

2 上传到云服务器上 运行
jmx监控启动参数 如下

java -Djava.rmi.server.hostname=xxx.x.xxx.xxx -Dcom.sun.management.jmxremote.port=10991 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -jar springboot_test-0.0.1-SNAPSHOT.jar
  • xxx.x.xxx.xxx 是要监控java程序所在服务器的外网ip
  • 10991 是jmx对外开放连接的端口可以自己设定别的端口值
  • springboot_test-0.0.1-SNAPSHOT.jar 是一个能正常运行的java jar程序

具体操作如下:

[root@hw-biz-alpha bin]# 
[root@hw-biz-alpha bin]# ll
total 18488
-rw-rw-r-- 1 admin admin 17355264 Sep 14 14:40 springboot_test-0.0.1-SNAPSHOT.jar
[root@hw-biz-alpha bin]# 
[root@hw-biz-alpha bin]# 
[root@hw-biz-alpha bin]# java -Djava.rmi.server.hostname=xxx.x.xxx.xxx -Dcom.sun.management.jmxremote.port=10991 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -jar springboot_test-0.0.1-SNAPSHOT.jar

我们开发所在的windows本地打开 安装了jdk后自带的监控客户端,在JAVA_HOME下面的bin 目录下面,例如我的是在 C:\Program Files\Java\jdk1.8.0_201\bin
监控客户端有3个 jConsole 、jmc 和 jvisualvm, 下面一一介绍连接

jConsole

双击jConsole.exe 打开jConsole 监控客户端,如下图
在这里插入图片描述
远程进程栏输入xxx.x.xxx.xxx:10991
用户名和密码没有设置不用输入任何值,点击连接
在这里插入图片描述
选择不安全的连接(jmx参数设置了不使用ssl连接)
连接成功后,如下:
在这里插入图片描述

注意:如果要设置jmx连接的账号密码,参数如下:

-Dcom.sun.management.jmxremote.password.file=config/jmxremote/jmxremote.password -Dcom.sun.management.jmxremote.access.file=config/jmxremote/jmxremote.access 

在启动的java程序所在目录下config/jmxremote/ 下 创建文件jmxremote.access 和 jmxremote.password

访问权限文件 jmxremote.access内容: (test 是账号名,readwrite是访问权限)

test readwrite

账号对应密码文件 jmxremote.password内容: (test是在access文件中存在的账号,123456是test账号的密码)

test 123456

上述我介绍的指定access和password文件所放路径是我项目中放的位置,你们可以根据自己需要修改.

注: 为了方便,本文所有的操作都是没有配置账号密码连接的。

jmc

双击jmc.exe 打开jmc监控客户端,如下图
在这里插入图片描述
连接远程jmx服务器
文件 -> 连接 -> 选择 创建新连接 下一步
在这里插入图片描述
在这里插入图片描述
然后选择 启动JMX 控制台 点击完成
在这里插入图片描述
在这里插入图片描述

jvisualvm

双击jvisualvm.exe 打开jvisualvm监控客户端,如下图
在这里插入图片描述
点击右上角 文件 -> 添加 JMX 连接
在这里插入图片描述
在这里插入图片描述
注意: jvisualvm 支持 Visual GC插件,是用来分析内存泄漏的利器,但是jmx连接不支持,需要在要分析的应用所在机器上启动 jstatd服务。 点这里了解 如何使用脚本简单、快速启动jstatd服务

本地无法连接远程服务器jmx

注意:java jmx监控会 随机 绑定2个tcp端口(无法通过配置指定固定端口),如果开启了防火墙或云服务器安全组端口限制的话,非常可能会导致本地windows客户端无法连接远程服务器jmx监控.
比如,我在阿里云控制台服务器安全组中将常用固定的端口之外的端口全部禁掉了,本地windows jmx客户端连接远程服务器jmx监控 会连接失败,如下:

连接失败:是否重试?
未成功连接到:xxx.x.xxx.xxx:10991。
是否要重试?

截图如下:
在这里插入图片描述

解决:

1 关闭防火墙,开放云服务器安全组所有tcp端口 (当然,这种方法不安全)
2 每次重启了java程序后需要去监控的时,通过查找到该程序jmx随机绑定的tcp端口,手动去 防火墙 和 云服务器安全组 开放端口

下面介绍第二种方法

1 找到进程id

ps -aux | grep 启动jar名

[admin@hw-biz-alpha ~]$ ps -aux | grep springboot_test-0.0.1-SNAPSHOT
root     22303  0.8  3.5 3032788 136584 pts/0  Sl+  19:05   0:08 java -Djava.rmi.server.hostname=xxx.x.xxx.xxx -Dcom.sun.management.jmxremote.port=10991 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -jar springboot_test-0.0.1-SNAPSHOT.jar
admin    22630  0.0  0.0 112708   992 pts/1    R+   19:22   0:00 grep --color=auto springboot_test-0.0.1-SNAPSHOT
[admin@hw-biz-alpha ~]$ 

找到进程id 是 22303

2 查看进得占用端口

sudo netstat -nap | grep 进程号

[admin@hw-biz-alpha ~]$ 
[admin@hw-biz-alpha ~]$ sudo netstat -nap | grep 22303
[sudo] password for admin: 
tcp6       0      0 :::43979                :::*                    LISTEN      22303/java          
tcp6       0      0 :::10991                :::*                    LISTEN      22303/java          
tcp6       0      0 :::46584                :::*                    LISTEN      22303/java               
unix  2      [ ]         STREAM     CONNECTED     18638343 22303/java           
unix  2      [ ]         STREAM     CONNECTED     18651557 22303/java           
[admin@hw-biz-alpha ~]$ 

找到jmx随机绑定的2个tcp端口是 43979 和 46584 (注意:10991是启动时配置的jmx客户端连接的端口,这个是通过jmx参数可以配置的)

3 防火墙和云服务器安全组开放端口

我这里用的是阿里云服务器,系统防火墙是关闭的,我现在在阿里云控制台将这个云服务器安全组端口权限开放 tcp 10991 、43979 和 46584

然后再次在本地用windows jmx客户端连接 远程服务器上java程序的jmx监控 连接成功 (亲测).

最后

本章介绍了本地jdk提供的3个图形jmx监控客户端,连接远程jmx服务器.以及解决可能出现的无法连接问题
下章 介绍 jConsole jmc jvisualvm 的使用。

这篇关于在本地windows用jConsole jmc jvisualvm监控图形客户端 连接远程服务器java程序jmx监控服务。解决jmx无法连接问题。jvm监控、性能调优工具的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab

Java 方法重载Overload常见误区及注意事项

《Java方法重载Overload常见误区及注意事项》Java方法重载允许同一类中同名方法通过参数类型、数量、顺序差异实现功能扩展,提升代码灵活性,核心条件为参数列表不同,不涉及返回类型、访问修饰符... 目录Java 方法重载(Overload)详解一、方法重载的核心条件二、构成方法重载的具体情况三、不构

如何在Ubuntu 24.04上部署Zabbix 7.0对服务器进行监控

《如何在Ubuntu24.04上部署Zabbix7.0对服务器进行监控》在Ubuntu24.04上部署Zabbix7.0监控阿里云ECS服务器,需配置MariaDB数据库、开放10050/1005... 目录软硬件信息部署步骤步骤 1:安装并配置mariadb步骤 2:安装Zabbix 7.0 Server

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构