无法在VisualVM中查看Visual GC

我在我的本地Windows机器上使用Java VisualVM来监视我的远程服务器(Linux)。 除了“ Visual GC ”之外,我能够在Bisual VM中获取所有统计数据。 它显示“此JVM不支持”。 我用google搜索它,发现它可能是因为jstatd没有运行和连接。 所以执行了“ jstatd -J-Djava.security.policy = / tmp / tools.policy ”。 它显示了一个ip“ 175.41.139.225 ”。 我无法理解为什么它试图连接到这个IP。 它不是我的远程机器的ip,也不是我的本地机器的ip。

[root@shipping_pt mail]# jstatd -J-Djava.security.policy=/tmp/tools.policy Could not contact registry Connection refused to host: 175.41.139.225; nested exception is: java.net.ConnectException: Connection refused java.rmi.ConnectException: Connection refused to host: 175.41.139.225; nested exception is: java.net.ConnectException: Connection refused at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:619) at sun.rmi.transport.tcp.TCPChannel.createConnection(TCPChannel.java:216) at sun.rmi.transport.tcp.TCPChannel.newConnection(TCPChannel.java:202) at sun.rmi.server.UnicastRef.newCall(UnicastRef.java:340) at sun.rmi.registry.RegistryImpl_Stub.rebind(Unknown Source) at java.rmi.Naming.rebind(Naming.java:177) at sun.tools.jstatd.Jstatd.bind(Jstatd.java:57) at sun.tools.jstatd.Jstatd.bind(Jstatd.java:66) at sun.tools.jstatd.Jstatd.main(Jstatd.java:143) Caused by: java.net.ConnectException: Connection refused at java.net.PlainSocketImpl.socketConnect(Native Method) at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:327) at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:193) at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:180) at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:384) at java.net.Socket.connect(Socket.java:546) at java.net.Socket.connect(Socket.java:495) at java.net.Socket.(Socket.java:392) at java.net.Socket.(Socket.java:206) at sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.java:40) at sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.java:146) at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:613) ... 8 more 

在远程服务器上

 vim /tmp/tools.policy 

加,

 grant codebase "file:${java.home}/../lib/tools.jar" { permission java.security.AllPermission; }; 

并开始jstatsd

 jstatd -J-Djava.security.policy=/tmp/tools.policy -J-Djava.rmi.server.hostname= 

并准备好在本地机器上的VisualVM内部使用Visual GC。

你是正确的,你需要运行jstatd才能使用VisualGC插件,因为VisualGC使用jvmstat API 。 看起来你是以root身份运行jstatd。 您是否监视以“root”身份运行的应用程序? /tmp/tools.policy文件怎么样? 尝试使用以下args运行jstatd:

 jstatd -J-Djava.rmi.server.hostname= -J-Djava.security.policy=/tmp/tools.policy 

VsiualVM非常依赖于版本。 如果你可以连接,但某些function不可用,我会确保你运行完全相同的Java版本。

如果无法连接,则需要更改JVM的权限。 注意:默认情况下,您只能看到您的进程。