JConsole和VisualVM远程访问JMX
1.jvisualvm监控tomcat
修改tomcat的bin目录下的 catalina.sh文件,搜索JAVA_OPTS="",在引号中添加参数
JAVA_OPTS="$JAVA_OPTS $JSSE_OPTS
-Djava.rmi.server.hostname=192.168.1.123
-Dcom.sun.management.jmxremote.port=12345
-Dcom.sun.management.jmxremote.ssl=false
-Dcom.sun.management.jmxremote.authenticate=false "
2.jvisualvm监控可执行jar
nohup java -Djava.rmi.server.hostname=192.168.1.123 -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=12345 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -jar test.jar &
3.打开本地JVisualVM,右击"远程"->添加添加远程主机(H),输入服务器地址
4.右击服务器地址->添加JMX连接,输入服务器地址和jmx端口
5.输入完成后即可监控到远程jar文件内存使用情况
可能出现异常情况:VisualVM 无法使用 service:jmx:rmi:///jndi/rmi:///jmxrmi 连接到xx.xx.xx.xx,关闭远程机器的防火墙即可
原因:除了JMX server指定的监听端口号外,JMXserver还会监听一到两个随机端口号,可以通过命netstat -tupln |grep <pid> 来查看当前java进程需要监听的随机端口号,将两个随机端口加入入站规则即可。
###开启用户认证
com.sun.management.jmxremote.authenticate=true
a) jmx连接使用安全凭证,需要单独设置
b) jar程序启动命令
java -Djava.rmi.server.hostname=192.168.1.123
-Dcom.sun.management.jmxremote
-Dcom.sun.management.jmxremote.port=12345
-Dcom.sun.management.jmxremote.ssl=false
-Dcom.sun.management.jmxremote.authenticate=true
-Dcom.sun.management.jmxremote.authenticate=true
-Dcom.sun.management.jmxremote.access.file=/usr/local/jmxremote.access
-Dcom.sun.management.jmxremote.password.file=/usr/local/jmxremote.password -jar test.jar
c) jmxremote.access内容
admin readwrite
jmxremote.access模板:
[用户名] [权限]
d) jmxremote.password内容
admin 123456
jmxremote.password模板:
[用户名] [密码] test test
e) 两个文件授权
注意:jmxremote.password和jmxremote.access文件只允许启动用户名对该文件拥有读写权限 ,我们服务用root启动 ,必须按下面方式授权,chmod777都不行
chmod 600 jmxremote.access
chmod 600 jmxremote.password
chown root:root jmxremote.access
chown root:root jmxremote.password
如果权限设置不正确会报错:Error: Password file read access must be restricted
没有高深的知识,没有进阶的技巧,万丈高楼平地起~!