Apache ActiveMQ浏览器无法连接到JMX控制台

时间:2013-09-30 11:24:02

标签: activemq jmx

我正在使用Apache ActiveMQ version 5.8.0,我下载了Apache ActiveMQ Browser version 2.5.2.8

在Apache ActiveMQ中,我编辑了activemq.xml配置以使用JMX:

<broker xmlns="http://activemq.apache.org/schema/core" useJmx="true" brokerName="localhost" dataDirectory="${activemq.data}">
  <!-- This needed to be set to true, otherwise JMX won't start in 5.8.0 -->
  <managementContext>
    <managementContext createConnector="true"/>
  </managementContext>
</broker>

在启动脚本中,我按如下方式设置JMX设置:

#ACTIVEMQ_SUNJMX_START="-Dcom.sun.management.jmxremote.port=11099 "
ACTIVEMQ_SUNJMX_START="$ACTIVEMQ_SUNJMX_START -Dcom.sun.management.jmxremote.password.file=${ACTIVEMQ_CONF}/jmx.password"
ACTIVEMQ_SUNJMX_START="$ACTIVEMQ_SUNJMX_START -Dcom.sun.management.jmxremote.access.file=${ACTIVEMQ_CONF}/jmx.access"
ACTIVEMQ_SUNJMX_START="$ACTIVEMQ_SUNJMX_START -Dcom.sun.management.jmxremote.ssl=false"
ACTIVEMQ_SUNJMX_START="$ACTIVEMQ_SUNJMX_START -Dcom.sun.management.jmxremote"

当我重新启动Apache ActiveMQ时,日志显示JMX已启动且可访问:

JMX consoles can connect to service:jmx:rmi:///jndi/rmi://localhost:1099/jmxrmi | org.apache.activemq.broker.jmx.ManagementContext | JMX connector

同时检查端口是否正在侦听结果进入侦听端口:

[me@server ~]$ netstat -lptun | grep 1099
(Not all processes could be identified, non-owned process info
 will not be shown, you would have to be root to see it all.)
tcp        0      0 :::1099                     :::*                        LISTEN      16775/java

Apache ActiveMQ正在服务器上运行。例如,在IP 10.0.0.100上。 Apache ActiveMQ Browser在我的PC上运行(10.0.0.200)。

当我尝试连接Apache ActiveMQ Browser时,连接会一直失败。我正在使用以下设置:

 JMX URL: service:jmx:rmi:///jndi/rmi://10.0.0.100:1099/jmxrmi
 JMX role: admin
 JMS password: activemq

此时我将用户和密码保留为 jmx.password jmx.access 的默认设置。

我还尝试连接putty为端口1099创建隧道到本地端口1099,然后连接到 localhost 而不是 10.0.0.100 以确保没有防火墙是问题。但都失败了。

我忘了什么吗?

4 个答案:

答案 0 :(得分:15)

不幸的是,JMX需要两个端口才能正常运行。默认情况下,第二个(RMI注册表端口)被随机选中,导致防火墙等问题。

从JDK7u4开始,您可以使用

-Dcom.sun.management.jmxremote.rmi.port=<port>

设置要使用的RMI端口。

答案 1 :(得分:8)

经过几个小时的痛苦。连接防火墙后的魔力。

<managementContext>
  <managementContext createConnector="true" rmiServerPort="1098"  connectorPort="1099"  />
</managementContext>

示例连接字符串:

service:jmx:rmi://10.0.4.14:1098/jndi/rmi://10.0.4.14:1099/jmxrmi

答案 2 :(得分:5)

如果您受JDK版本的限制,那么不能使用-Dcom.sun.management.jmxremote.rmi.port,您也可以在managementContext本身中指定RMI注册表端口。

<broker xmlns="http://activemq.apache.org/schema/core" useJmx="true" brokerName="localhost" dataDirectory="${activemq.data}">
    ...
    <managementContext>
        <managementContext connectorPort="1099" rmiServerPort="<port>" />
    </managementContext>
    ...
</broker>

答案 3 :(得分:0)

对我来说,我得到了:Connection refused to host: ; nested exception is: ....,即使它是在其jmx端口上进行TCP侦听的。

似乎我还需要-Djava.rmi.server.hostname = my.local.ip.address,然后它可以与正常的连接网址一起使用

 service:jmx:rmi:///jndi/rmi://host:your_jmxremote_port/jmxrmi

不确定为什么...

可能在activemq端也需要此,不确定:

--jmxurl service:jmx:rmi:///jndi/rmi://127.0.0.1:11099/jmxrmi