我正在使用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 以确保没有防火墙是问题。但都失败了。
我忘了什么吗?
答案 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