无法在VisualVM中查看Visual GC

aja*_*jay 4 java linux profiler visualvm

我在我的本地Windows机器上使用Java VisualVM来监视我的远程服务器(Linux).除了" Visual GC " 之外,我能够在Bisual VM中获取所有统计数据.它显示"此JVM不支持".我用谷歌搜索它,发现它可能是因为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.<init>(Socket.java:392)
        at java.net.Socket.<init>(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
Run Code Online (Sandbox Code Playgroud)

小智 8

在远程服务器上

vim /tmp/tools.policy
Run Code Online (Sandbox Code Playgroud)

加,

grant codebase "file:${java.home}/../lib/tools.jar" {
   permission java.security.AllPermission;
};
Run Code Online (Sandbox Code Playgroud)

然后开始jstatsd

jstatd -J-Djava.security.policy=/tmp/tools.policy -J-Djava.rmi.server.hostname=<public_ip>
Run Code Online (Sandbox Code Playgroud)

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


Tom*_*rka 5

正确的是,您需要运行jstatd才能使用VisualGC插件,因为VisualGC使用jvmstat API。看来您jstatd以root用户身份运行。您是否以“ root”身份运行应用程序?/tmp/tools.policy文件的外观如何?尝试使用以下参数运行jstatd:

jstatd -J-Djava.rmi.server.hostname=<IP address of shipping_pt machine> -J-Djava.security.policy=/tmp/tools.policy
Run Code Online (Sandbox Code Playgroud)


Pet*_*rey 3

VsiualVM 非常依赖版本。如果您可以连接,但某些功能不可用,我将确保您运行的是完全相同的 Java 版本。

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