Java_jvisualvm使用JMX连接远程机器

本文介绍了使用JMX远程连接监控Java程序的方法。包括启动普通jar程序时的参数设置、异常处理及远程连接开启认证和SSL的配置;还说明了通过JDK工具远程监控有防火墙的Linux上Tomcat服务的步骤,如添加jar包、修改配置文件、开通防火墙端口等。

https://my.oschina.net/heroShane/blog/196227

 

一、启动普通的jar程序

1、执行foo.jar启动命令

java -Dcom.sun.management.jmxremote.port=12345 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -jar foo.jar

 

2、12345为需要监控的端口,远程机器需要开启

 

3、foo.jar为程序名称

 

4、本机jvisualvm添加监控

 

 

5、异常情况:VisualVM 无法使用 service:jmx:rmi:///jndi/rmi:///jmxrmi 连接到

关闭远程机器的防火墙即可:service iptables stop

不关闭防火墙的解决方案:http://qian0021514578.iteye.com/blog/2189041

原因:

除了JMX server指定的监听端口号外,JMXserver还会监听一到两个随机端口号,
可以通过命grep <pid> 来查看当前java进程需要监听的随机端口号

 

6、远程连接启动authenticatessl参数

http://softbeta.iteye.com/blog/1264833

以authenticate设置为例

a)  jmx连接使用安全凭证,这里的凭证不是linux的登录账号密码,需要单独设置

 

b)  jar程序启动命令

java -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 foo.jar

 

c) jmxremote.access内容

admin readwrite

 

d) jmxremote.password内容

admin 123456

使用 service:jmx:rmi:///jndi/rmi:///jmxrmi 连接到XX.xx.xx.x

e) 两个文件授权(必须按下面方式授权,chmod777都不行)

chmod 600 jmxremote.access
chmod 600 jmxremote.password
chown root:root jmxremote.access
chown root:root jmxremote.password
 
f) jvisual vm使用
 

 

 

 

二、监控tomcat程序

 JDK的bin目录下有jvisualvm或jconsole可以监控本地和远程jvm实例的运行动态(包括cpu,内存等),

对于性能分析或内存泄露分析等极其方便。下面介绍如何通过这两个工具远程监控有防火墙的linux上的tomcat服务。

废话少说,直接上正题:

我的测试环境是:centos 6.2(IP为192.168.1.118)上通过jsvc将tomcat 7作为服务启动。

 

1. 下载http://mirror.bjtu.edu.cn/apache/tomcat/tomcat-7/v7.0.28/bin/extras/catalina-jmx-remote.jar并放在tomcat7的$CATALINA_BASE/lib目录。

2. 修改tomcat7的$CATALINA_BASE/conf/server.xml,在<Server port="8005" shutdown="SHUTDOWN"> 下加入监听器:

<Listener className="org.apache.catalina.mbeans.JmxRemoteLifecycleListener"

          rmiRegistryPortPlatform="10001" rmiServerPortPlatform="10002" />

3.建立文本文件$CATALINA_BASE/conf/jmxremote.password,其内容为:admin letmein

4.建立文本文件$CATALINA_BASE/conf/jmxremote.access,其内容为:admin readwrite

5.修改jsvc的服务启动配置文件,加入启动参数,如:

CATALINA_OPTS="$CATALINA_OPTS -Xms128m -Xmx200m -XX:PermSize=64M -XX:MaxPermSize=256m -XX:+UseConcMarkSweepGC \

-Djava.rmi.server.hostname=192.168.1.118 \

-Dcom.sun.management.jmxremote.password.file=$CATALINA_BASE/conf/jmxremote.password \

-Dcom.sun.management.jmxremote.access.file=$CATALINA_BASE/conf/jmxremote.access \

-Dcom.sun.management.jmxremote.ssl=false"

6.开通linux防火墙的端口:10001和10002.(例如:在/etc/sysconfig/iptables中加入

-A INPUT -m state --state NEW -m tcp -p tcp --dport 10001 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp --dport 10002 -j ACCEPT),

注意要重启防火墙使生效。

7.至此远程可以使用jvisualvm或jconsole通过地址:(192.168.1.118:10001或者service:jmx:rmi:///jndi/rmi://192.168.1.118:10001/jmxrmi),使用用户admin密码letmein登录

动态监控tomcat服务了.

 

    参考地址:http://tomcat.apache.org/tomcat-7.0-doc/config/listeners.html

### 配置 JVisualVM 实现远程连接 #### 使用 JMX 方式配置 Tomcat JVM 进程 为了使 JVisualVM 能够通过 JMX 技术监控远程的 Tomcat JVM 进程,需修改 `catalina.sh` 或者 Windows 下对应的 `catalina.bat` 文件中的环境变量设置部分。具体来说是在文件里找到并编辑 `JAVA_OPTS` 参数,加入以下内容来启用 JMX远程管理接口[^4]: ```bash -Dcom.sun.management.jmxremote \ -Dcom.sun.management.jmxremote.port=6666 \ -Djava.rmi.server.hostname=192.168.12.141 \ -Dcom.sun.management.jmxremote.ssl=false \ -Dcom.sun.management.jmxremote.authenticate=false ``` 上述命令中 `-Djava.rmi.server.hostname` 应替换为实际服务器 IP 地址;端口号可以根据实际情况调整。 #### 启动 Java 程序以便被 JVisualVM 监控 对于一般 Java 应用程序而言,除了上面提到针对特定服务如 Tomcat 的特殊配置外,也可以直接在启动应用程序时指定类似的参数以允许其接受来自 JVisualVM远程连接请求[^3]。 #### 添加远程主机至 JVisualVM 打开位于 JDK 安装路径下的 bin 文件夹内的 jvisualvm.exe 可执行文件后,在图形界面左侧列表选择“远程”,点击右键菜单项“添加远程主机...”。输入目标机器名称或 IP 即可完成添加操作。此时应该能够看到已部署的应用及其性能指标概览信息[^1]。 请注意当采用 jstatd 方法建立远程会话时不提供 CPU 和内存采样的功能选项,这可能会影响某些场景下的诊断效率。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值