阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

使用本地JConsole监控远程JVM(最权威的总结)

462次阅读
没有评论

共计 2754 个字符,预计需要花费 7 分钟才能阅读完成。

问题背景
  Tomcat 经常崩溃 crash,想看看 JVM 内存使用情况,就想到了用 Jconsole 监控,以前只是监控本地的 JVM,这次要监控远程的,遇到了不少问题。
  经过几个小时的努力,参考了众多网友的资料之后,才最终解决了这个问题。
  比较坑爹的是,网上的资料,竟然没有一个是:完美无缺的,没有一篇文章提到了“jmxremote.access”这个文件的重要性。
 
第一阶段
  找到了 2 种配置,是否需要输入密码。
   JAVA_OPTS=”$JAVA_OPTS -Dcom.sun.management.jmxremote.port=60001″
   JAVA_OPTS=”$JAVA_OPTS -Dcom.sun.management.jmxremote.authenticate=false”
   JAVA_OPTS=”$JAVA_OPTS -Dcom.sun.management.jmxremote.ssl=false”
   
   authenticate 为 false,jconsole 连接远程 jvm 时,就不需要输入用户名和密码。
   否则,要配置密码文件和密码。
   可以指定密码文件的位置
   JAVA_OPTS=”$JAVA_OPTS -Dcom.sun.management.jmxremote.pwd.file=/root/soft/jdk7/jre/lib/management/jmxremote.password”
   
   我把这些配置放在了 catalish.sh 中。
   
第二阶段
   上面的配置遇到了一个问题,如果是第一次启动正常,但是当 shutdown 时,提示端口号被占用了。
   问题原因是,在关闭 Tomcat 时,也执行了 Catalish 中的 jmxremote 的端口号。
   
   解决办法:在 catalish.sh 文件中,判断是否为启动命令,如果是 start,就设置变量,否则,就不设置。
   相关脚本:
   JAVA_OPTS=”$JAVA_OPTS -Xms256m -Xmx1024m -XX:PermSize=128M -XX:MaxPermSize=256m”
101 if [“$1” = “start”];then
102      echo “set console”;
103 #   JAVA_OPTS=”$JAVA_OPTS -Xms256m -Xmx1024m -XX:PermSize=128M -XX:MaxPermSize=256m”
104     JAVA_OPTS=”$JAVA_OPTS -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=60001 -Djava.rmi.server.hostname=42.96.84.84″;
105     JAVA_OPTS=”$JAVA_OPTS -Dcom.sun.management.jmxremote.authenticate=false”;
106     JAVA_OPTS=”$JAVA_OPTS -Dcom.sun.management.jmxremote.ssl=false”;
107 #   JAVA_OPTS=”$JAVA_OPTS -Dcom.sun.management.jmxremote.pwd.file=/root/soft/jdk7/jre/lib/management/jmxremote.password”
108 else
109   echo “no startup”;
110 fi;
111
 
第三阶段
   上面的设置之后,可能还连接不上,需要配置“java.rmi.server.hostname”为机器的 ip,比如我的是“42.96.84.84”。
   
   然后,重启 Tomcat,在本地 Jconsole 连接远程 JVM,只输入“42.96.84.84:60001”。
 
   
第四阶段
   登录使用密码,搞了几个小时,尼玛。
   
   注意问题
   1.-Dcom.sun.management.jmxremote.authenticate=true
   2.-Dcom.sun.management.jmxremote.pwd.file 指定正确的密码文件
   3. 用户名及密码 (参考 jmxremote.password 文件) monitorRole 只能读,controlRole 能读写 
     配置中的安全原因出错,由于密码是以明文的方式保存在:jmxremote.password 中,所以对此文件只能有所有者都读取,其他人都不能读取。
 权限需要注意,600, 所有者有 rw 权限。
   4. 用户和权限其实是存在 jmxremote.access 中。
   千万要注意啊,网上的绝大部分资料,都没有提到这个文件的真正作用。
   我是在尝试了若干小时之后,才发现这个文件的作用,竟然是如此的大。
   有点类似于 SVN 配置,用户名 - 权限,用户名 - 密码,2 个配置文件。
   fansunion   readonly
   admin   readwrite \
                 create javax.management.monitor.*,javax.management.timer.* \
                 unregister
 
jmxremote.password 内容
fansunion  12345
admin  12345
 
“http://www.linuxidc.com/Linux/2015-02/113415.htm”这篇文章的最后,
   “ 用户名及密码 (参考 jmxremote.password 文件) monitorRole 只能读,controlRole 能读写 ”,给我很大的启发。
   为什么 monitorRole 和 controlRole,这 2 个角色的权限还不一样呢,默认注释的 password 文件中,没有看出有啥区别呀。
   于是,我才去 jmxremote.access 文件看了看,最终找到了问题的症结。
   
   至此,不使用密码和使用用户名及密码,“admin”-“12345”成功登录 42.96.84.84 上的 Tomcat 使用的 JVM。
   
   注意:本文中的 ip、用户名、密码,仅供参考,你懂的。
   
参考资料
 
1. 入门参考
http://www.linuxidc.com/Linux/2015-02/113413.htm
http://www.linuxidc.com/Linux/2015-02/113418.htm
 
2. 最权威的
http://www.linuxidc.com/Linux/2015-02/113419.htm
 
3. 给我很大的启发,解决用户名和密码登录问题
http://www.linuxidc.com/Linux/2015-02/113415.htm
正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-20发表,共计2754字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19350
评论数
4
阅读量
7956568
文章搜索
热门文章
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见 zabbix!轻量级自建服务器监控神器在 Linux 的完整部署指南 在日常运维中,服务器监控是绕不开的...
飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛 NAS 中安装 Navidrome 音乐文件中文标签乱码问题解决、安装 FntermX 终端 问题背景 ...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择

星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择

星哥带你玩飞牛 NAS-12:开源笔记的进化之路,效率玩家的新选择 前言 如何高效管理知识与笔记,已经成为技术...
星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

  星哥带你玩飞牛 NAS-16:不再错过公众号更新,飞牛 NAS 搭建 RSS 对于经常关注多个微...
把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地 大家好,我是星哥,今天教大家在飞牛 NA...
12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换

12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换

12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换...
星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛 NAS 硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话? 前言 在选择 NAS 用预...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地 大家好,我是星哥,今天教大家在飞牛 NA...
多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞...
星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛 NAS 硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话? 前言 在选择 NAS 用预...
Prometheus:监控系统的部署与指标收集

Prometheus:监控系统的部署与指标收集

Prometheus:监控系统的部署与指标收集 在云原生体系中,Prometheus 已成为最主流的监控与报警...
支付宝、淘宝、闲鱼又双叕崩了,Cloudflare也瘫了连监控都挂,根因藏在哪?

支付宝、淘宝、闲鱼又双叕崩了,Cloudflare也瘫了连监控都挂,根因藏在哪?

支付宝、淘宝、闲鱼又双叕崩了,Cloudflare 也瘫了连监控都挂,根因藏在哪? 最近两天的互联网堪称“故障...