我的應用程序在jetty容器中運行。我已經初始化了jetty容器下的JMX過程。這些所有進程都在docker容器下運行。 當我嘗試使用JCONSOLE進行遠程連接來連接我的JMX主機:端口時,我無法連接。無法在Docker上運行應用程序時遠程進行JMX連接
我的物理主機:matrix01lx(這是搬運工容器運行) 我的搬運工虛擬IP地址:172.17.0.2。
現在,當我想連接使用JMX我能夠連接,只有當我從物理主機的docker容器正在運行的連接,即matrix01lx在我的情況。
我連接使用:通過JConsole的連接說法時service:jmx:rmi://host/jndi/rmi://matrix01lx:11041/smp.serverruntime
遠程連接失敗,
java.rmi.ConnectException: Connection refused to host: **172.17.0.2**; nested exception is:
java.net.ConnectException: Connection timed out: connect
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.invoke(UnicastRef.java:129)
at javax.management.remote.rmi.RMIServerImpl_Stub.newClient(Unknown Source)
at javax.management.remote.rmi.RMIConnector.getConnection(RMIConnector.java:2404)
at javax.management.remote.rmi.RMIConnector.connect(RMIConnector.java:308)
at javax.management.remote.JMXConnectorFactory.connect(JMXConnectorFactory.java:268)
at com.sigma.jmxClient.Connect.main(Connect.java:53)
Caused by: java.net.ConnectException: Connection timed out: connect
at java.net.DualStackPlainSocketImpl.connect0(Native Method)
at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:79)
at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:339)
at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:200)
at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:182)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)
at java.net.Socket.connect(Socket.java:579)
at java.net.Socket.connect(Socket.java:528)
at java.net.Socket.<init>(Socket.java:425)
at java.net.Socket.<init>(Socket.java:208)
at sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.java:40)
at sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.java:147)
at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:613)
... 8 more
我已經指到論壇,並試圖按照我MAVEN_OPTS屬性設置在代碼開始MVN過程中,明確當以及。
-Dcom.sun.management.jmxremote
-Dcom.sun.management.jmxremote.authenticate=false
-Dcom.sun.management.jmxremote.ssl=false
-Dcom.sun.management.jmxremote.rmi.port=11041
-Djava.rmi.server.hostname=matrix01lx (also tried putting IP address here)
注意:我曾嘗試禁用防火牆。我正在使用centOS 7
請建議!
java.rmi.server.hostname = matrix01lx是解析,它的IP地址是說10.11.10.22,如果你當我們使用** matrix01lx **連接時,請在日誌中查看,這會嘗試連接docker contianer主機IP,如上面日誌中所示。那個主持人沒有解決,我認爲這是失敗的。 – Sohan
爲什麼JCONSOLE試圖連接到** 172.17.0.2 **? java.rmi.server.hostname = matrix01lx,jmxremote.port和jmxremote.rmi.port設置爲11041,並且在jconsole機器上將matrix01lx解析爲10.11.10.22,是否正確?沒有涉及域名? –
是的正確,但它試圖做的是,因爲matrix01lx有docker容器運行在那裏它已經發布JMX的端口11041,它知道碼頭的主機即172.17.0.2,所以最終從遠程有人試圖連接JMX到最後它得到碼頭的IP地址。不知道爲什麼會發生這種情況。即使它獲得碼頭IP,172.17.0.2已經由matrix01lx rigth解決了,? 發生了一些奇怪的事情。 – Sohan