gpt4 book ai didi

jmx - VisualVM over Putty SSH 隧道

转载 作者:行者123 更新时间:2023-12-04 02:19:30 25 4
gpt4 key购买 nike

我正在尝试分析远程 Java 应用程序,实际上它是一个游戏服务器。它在我的本地计算机(带有 JDK1.7.0_02 x64 的 Windows XP x64)上正常工作,但在生产服务器(带有 JDK1.7.0_03 i586 的 CentOS)上表现非常奇怪。

我进行了大量搜索,发现我应该使用 VisualVM 来完成这项任务。所以 VisualVM 在本地机器上运行良好,但在本地机器上没有挂起,我需要在生产环境中使用真实负载进行分析。我在远程机器上用参数启动了 jstatd

jstatd -J-Djava.security.policy=jstatd.all.policy -J-Djava.rmi.server.logCalls=false &

使用策略文件

grant codebase "file:/usr/java/jdk1.7.0_02/lib/tools.jar" {
permission java.security.AllPermission;
};

然后我就这样开始了我的java应用

java -server -Dcom.sun.management.jmxremote\
-Dcom.sun.management.jmxremote.port=4000\
-Dcom.sun.management.jmxremote.ssl=false\
-Dcom.sun.management.jmxremote.authenticate=false\
-jar /home/pinballSocketServer/pinballSocketServer.jar

应用程序和 jstatd 都以 root 权限启动。

并且 VisualVM 无​​法连接到远程主机。但是在远程主机上,当 VisualVM 正在运行并添加了远程主机时,我看到了以下日志:

Feb 16, 2012 7:11:52 PM sun.rmi.server.UnicastServerRef logCall
FINER: RMI TCP Connection(3)-217.16.27.195: [217.16.27.195: sun.rmi.registry.RegistryImpl[0:0:0, 0]: java.rmi.Remote lookup(java.lang.String)]
Feb 16, 2012 7:11:56 PM sun.rmi.server.UnicastServerRef logCall
FINER: RMI TCP Connection(3)-217.16.27.195: [217.16.27.195: sun.rmi.registry.RegistryImpl[0:0:0, 0]: java.rmi.Remote lookup(java.lang.String)]
Feb 16, 2012 7:12:00 PM sun.rmi.server.UnicastServerRef logCall
FINER: RMI TCP Connection(3)-217.16.27.195: [217.16.27.195: sun.rmi.registry.RegistryImpl[0:0:0, 0]: java.rmi.Remote lookup(java.lang.String)]
Feb 16, 2012 7:12:04 PM sun.rmi.server.UnicastServerRef logCall
FINER: RMI TCP Connection(3)-217.16.27.195: [217.16.27.195: sun.rmi.registry.RegistryImpl[0:0:0, 0]: java.rmi.Remote lookup(java.lang.String)]

进一步谷歌搜索后,我发现我需要使用 ssh 隧道。我通过以下方式配置了腻子

http://www.advancedigital.ru/show/putty_config.jpg

和 VisualVM 一样

http://www.advancedigital.ru/show/visualvm_config.jpg

VisualVM 上方的 Adter 操作连接到远程主机,但我只能看到线程摘要图表并且分析器处于非事件状态。

我看到一些建议,两台机器上的 jvms 应该相似并且具有相同的平台(x86 或 x64),但我已经尝试从另一台机器(带有 JDK1.7.0_03 x86 的 Windows 7 x86)进行分析,并且有相同的结果。

我也试过这个,但还是得到了同样的结果。 VisualVM over ssh

我怎样才能让这个分析工作?

最佳答案

即使已经回答了这个问题,我还是设法做到了,所以我将添加我的方法:

我使用了以下来源:

https://bowerstudios.com/node/731

我在 Windows 中使用具有 ssh 命令的 git bash 完成了此操作。您也可以使用 cygwin 或纯 minggw。

1) 在命令提示符下运行 ssh tunnel 命令(我在 git bash/MINGGW32 中执行此操作)。

ssh -D 9010 -p 22 root@IP -v

2) 使用 JMX 选项在服务器上运行您的应用程序(一个衬里)

 java -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=9010 
-Dcom.sun.management.jmxremote.local.only=false
-Dcom.sun.management.jmxremote.authenticate=false
-Dcom.sun.management.jmxremote.ssl=false -jar application.jar

3)通过socks代理运行visualVM进行连接(一个liner)

visualvm -J-Dnetbeans.system_socks_proxy=localhost:9010 
-J-Djava.net.useSystemProxies=true

4) 在visualVM中实际添加你的JMX远程连接

也可用:http://maythesource.com/2013/12/04/connecting-to-jmx-from-visualvm-using-ssh-tunnel/ (随着时间的推移会更新更多信息)。

关于jmx - VisualVM over Putty SSH 隧道,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9314092/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com