visualVM 使用 remote 连接远程机器上的Tomcat

本文介绍了如何使用VisualVM远程连接到Tomcat,主要涉及jstatd的启动和Tomcat的配置。在Tomcat的catalina.sh中添加特定参数,解决连接问题。同时,详细说明了启动jstatd的步骤,包括创建policy文件和使用命令行启动。完成这些配置后,即可成功实现VisualVM的远程连接。

标签(空格分隔): jdk visualvm


refer:
http://blog.markshead.com/1129/connecting-visual-vm-to-tomcat-7
http://docs.oracle.com/javase/6/docs/technotes/tools/share/jstatd.html


其实配置主要包含两个方面:
1. jstatd 的启动
2. Tomcat的配置


1. tomcat 配置:

在 /bin/catalina.sh 中配置:

JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote=true -Dcom.sun.management.jmxremote.port=8090 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Djava.rmi.server.hostname=192.168.158.204"

jmx 的参数具体如下

-Dcom.sun.management.jmxremote=true 
-Dcom.sun.management.jmxremote.port=8090  // 端口
-Dcom.sun.management.jmxremote.authenticate=false  
-Dcom.sun.management.jmxremote.ssl=false 
-Djava.rmi.server.hostname=192.168.158.204 

一般连接的时候,会遇到以下问题:

此处输入图片的描述

造成以上问题的原因会两个:

1.tomcat中的catalina.sh的配置不对,即少赔了以下参数

 -Djava.rmi.server.hostname=192.168.158.204  

2.jstatd在 remote machine上没有启动.


如何启动 jstatd

jstatd的端口是默认是 1099,可以检查该端口是否已经有进程在使用.
此处输入图片的描述

1.创建一个 policy文件:

 grant codebase "file:${java.home}/../lib/tools.jar" {

       permission java.security.AllPermission;

    };

2.使用命令启动 ( jstatd 在java_home的bin下面)

./jstatd -J-Djava.security.policy=../security/jstatd.all.policy -J-Djava.rmi.server.hostname=192.168.158.204 &

注意:

-J-Djava.rmi.server.hostname: 该IP是 jstatd 所在的机器的IP,即remote machine的IP;         
如果没有这个IP,同样也是会报"  Cannot connect to xxxx:port using ..." 的错误的

启动好之后,再次连接,就会自动连接上了.


最后的效果图

此处输入图片的描述

### 使用 JVisualVM 连接远程主机 为了使 JVisualVM 能够连接远程主机上的 JVM 实例,需遵循特定的配置步骤来确保安全性和功能性。初次加载 JVisualVM 并不会自动建立 SSL 远程连接至目标 JVM;这一步骤需要手动完成[^1]。 #### 配置远程主机并添加JMX连接 当准备就绪,在本地启动 JVisualVM 后,通过菜单选项“文件-添加远程主机”,可以增加新的远程机器条目[^2]。对于 Tomcat 或其他应用服务器而言,具体操作涉及先选择 `Remote` 下拉列表中的 `Add Remote Host...` 项,并输入相应的 IP 地址或域名以创建新记录[^3]。 一旦确认无误地保存了这些更改,则可以在同一级目录下的已知节点里找到刚才定义好的远端位置。此时应继续执行命令:右击该节点 -> `Add JMX Connection...` 来指定用于监控的具体 Java 应用实例及其监听端口号等必要参数。 #### 设置Java应用程序以便接受外部管理请求 为了让上述过程顺利进行,还需调整待监测的服务端程序本身。例如 Linux 上运行的应用可通过向启动脚本追加如下环境变量实现: ```bash nohup java -jar \ -Dcom.sun.management.jmxremote=true \ -Djava.rmi.server.hostname=127.0.0.1 \ -Dcom.sun.management.jmxremote.port=8082 \ -Dcom.sun.management.jmxremote.ssl=false \ -Dcom.sun.management.jmxremote.authenticate=false \ ~/server.jar & ``` 此段指令不仅启用了 JMX 功能,还关闭了 SSL 加密以及身份验证机制(出于简化测试目的),同时绑定了 RMI 接口至 localhost 的固定端口上等待来自 VisualVM 客户端发起的连接尝试[^4]。 另外值得注意的是,如果所选通信信道已被占用或者防火墙策略阻止访问,则可能导致握手失败等问题发生。因此建议事先核查网络状况并适当放宽规则限制以保障整个流程畅通无阻[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值