我正在尝试使用jstatd使用jps查询远程JVM,以便最终使用VisualVM监视它。
我使用以下安全策略运行jstatd:
grant codebase "file:${java.home}/../lib/tools.jar" {
permission java.security.AllPermission;
};jstatd在64位Linux机器上运行,安装了1.6.0_10版本的HotSpot虚拟机。jstatd命令为:
jstatd -J-Djava.security.policy=jstatd.tools.policy -J-Djava.rmi.server.logCalls=true我正在尝试从Windows7机器上运行jps。由于防火墙的限制,我通过SSH隧道将RMI数据通过隧道传输到我的Windows计算机,因此jps命令行是:
.\jps.exe -m -l rmi://localhost当我运行jps时,我在jstatd日志中看到连接尝试,如下所示:
Feb 1, 2011 11:50:34 AM sun.rmi.server.UnicastServerRef logCall
FINER: RMI TCP Connection(3)-127.0.0.1: [127.0.0.1: sun.rmi.registry.RegistryImpl[0:0:0, 0]: java.rmi.Remote lookup(ja va.lang.String)]但在jps端,我得到了以下错误:
Error communicating with remote host: Connection refused to host: 192.168.1.137; nested exception is:
java.net.ConnectException: Connection refused: connect根据jstatd日志中列出的连接尝试,我认为jps实际上正在到达主机,但由于某种原因正在被阻止。是否有一些我已经设置的安全策略或其他设置可以更改,以便让jps从远程jstatd获取统计数据?
发布于 2011-02-02 01:39:08
我的猜测是,您只转发了RMI注册端口(1099),但您还需要打开另一个端口。
检查远程端的哪些端口
# netstat -nap | grep jstatd
tcp 0 0 :::1099 :::* LISTEN 453/jstatd
tcp 0 0 :::58204 :::* LISTEN 453/jstatd 在这种情况下,您需要转发端口58204和1099
https://stackoverflow.com/questions/4865650
复制相似问题