使用jconsole或jvisualVM远程监控可执行jar(非Tomcat)运行状况的配置

 

 

前言:利用java自带的工具,分析springboot项目jar,本地或远程程序运行的cpu,线程,堆,内存使用情况。

第一种方式:

使用如下命令启动需要监控的jar包:

java -Djava.rmi.server.hostname=远程服务器ip -Dcom.sun.management.jmxremote.port=10034  -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Xms4096m -Xmx4096m -Xss512k -jar xxx.jar

解释:

首先了解两个概念:

  1. Java RMI:Java远程方法调用,即Java RMI(Java Remote Method Invocation)
  2. Java JMX: Java管理扩展,即Java JMX(Java Management Extensions)

参数解析:

-Djava.rmi.server.hostname=远程服务器ip    //配置远程调用主机地址,即jar包运行所在系统的IP地址,不配置则默认使用hosts文件中的值
-Dcom.sun.management.jmxremote.port=10034    //指定JMX的运行端口,jconsole需要对接的既是该端口
-Dcom.sun.management.jmxremote.ssl=false        // 是否允许使用ssl方式接入
-Dcom.sun.management.jmxremote.authenticate=false    //是否需要进行身份验证

连接示例:

打开jconsole 位置D:\Program Files\Java\jdk1.8.0_201\bin下,这个是我电脑上安装的jdk路径

A.jconsole

 

 

 

 

B.jvisualVM

第二种方式:

首先在服务器终端设置环境变量,主要是便于每次启动项目时使用:

export JAVA_OPTS='-Djava.rmi.server.hostname=你的服务器地址(公网ip) -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=8888 -Dcom.sun.management.jmxremote.rmi.port=8888 -Dcom.sun.management.jmxremote.authenticate=true -Dcom.sun.management.jmxremote.ssl=false'

 

参数和上面一样,就不解释了

导入环境变量后,用命令重新加载配置文件:source /etc/profile;可以直接将export命令写入profile文件最后,在加载文件便可以保持该环境变量一直生效。

切换到你服务器的jvm配置路径:/usr/lib/jvm/...

拷贝jmxremote.password.template文件到jmxremote.pwssword:

添加写入权限:

然后对文件进行修改:vim jmxremote.password

取消最后两行的注释,保存退出。

这里默认的用户有monitorRole和controlRole,对应的密码分别是QED和R&D

注意:这里的monitorRole只有读权限,而controlRole有读写权限

启动项目进行测试:

 

客户端打开jconsole,输入对应的信息:

如果提示仍然是连接失败,需要对服务器开放端口进行检查查看端口是否正在监听,或者防火墙策略是否开放当前端口:

查看指定端口监听状态:sudo netstat -apn | grep java

可以看见8888端口正处于监听状态,则说明是防火墙的问题。可以使用iptables -F 命令关闭防火墙,也可以配置云服务器安全组打开指定的端口。

再次尝试连接,连接成功:

参考网站资料:

https://blog.csdn.net/DDKii/article/details/83663692

https://blog.csdn.net/Box_clf/article/details/88344631

https://blog.csdn.net/luosai19910103/article/details/75574725

https://blog.csdn.net/Box_clf/article/details/88344631

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值