无法在Docker上运行应用程序时远程进行JMX连接
我的应用程序在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应用程序。
java.rmi.server.hostname应与您连接的主机名相同。 确保它可以从原始机器解析。
-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=1090 -Dcom.sun.management.jmxremote.rmi.port=1090 -Dcom.sun.management.jmxremote.ssl=false -Djava.rmi.server.hostname=matrix01lx -Dcom.sun.management.jmxremote.password.file=${ACTIVEMQ_CONF}/jmx.password -Dcom.sun.management.jmxremote.access.file=${ACTIVEMQ_CONF}/jmx.access
集装箱见工作示例为ActiveMQ的:
https://github.com/axibase/atsd/tree/master/integration/activemq
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