基于Springboot项目使用jconsole远程监控JVM

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

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'

参数解析:

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

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

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

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

添加写入权限:

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

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

这里默认的用户有monitorRolecontrolRole,对应的密码分别是QEDR&D

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

基于Springboot项目使用jconsole远程监控JVM_第1张图片

启动项目进行测试:

基于Springboot项目使用jconsole远程监控JVM_第2张图片

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

基于Springboot项目使用jconsole远程监控JVM_第3张图片

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

基于Springboot项目使用jconsole远程监控JVM_第4张图片

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

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

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

基于Springboot项目使用jconsole远程监控JVM_第5张图片

你可能感兴趣的:(JVM)