使用 Jolokia 监视 activemq 队列



使用 activemq jms for queue机制,我想监视我的队列,例如队列的大小。我正在使用Jolokia作为在JMX上执行休息请求的桥梁。

队列在野蝇中配置并且工作正常:

<subsystem xmlns="urn:jboss:domain:messaging-activemq:1.0">
<server name="default">
<http-connector name="http-connector" socket-binding="http" endpoint="http-acceptor"/>
...
</http-connector>
<http-acceptor name="http-acceptor" http-listener="default"/>
...
</http-acceptor>
<jms-queue name="QueueName" entries="java:/jms/queue/QueueName"/>
<pooled-connection-factory name="activemq-ra" entries="java:/JmsXA java:jboss/DefaultJMSConnectionFactory" connectors="in-vm" transaction="xa"/>
</server>
</subsystem>

我已经在部署下的野蝇上部署了 Jolokia 战争文件,以下 url 为我带来了属性列表:

localhost:8080/jolokia/list 

现在我想阅读有关我的队列的信息,所以我使用以下 rest 请求:

localhost:8080/jolokia/read/org.apache.activemq.artemis:module=JMS,type=Queue,name=*QueueName*

但是,这会引发以下异常:

"stacktrace": "javax.management.InstanceNotFoundException: No MBean with pattern org.apache.activemq.artemis:module=JMS,type=Queue,name=*QueueName* found for reading attributesntat org.jolokia.handler.ReadHandler.searchMBeans(ReadHandler.java:160)ntat org.jolokia.handler.ReadHandler.fetchAttributesForMBeanPattern(ReadHandler.java:126)ntat org.jolokia.handler.ReadHandler.doHandleRequest(ReadHandler.java:116)ntat org.jolokia.handler.ReadHandler.doHandleRequest(ReadHandler.java:37)ntat org.jolokia.handler.JsonRequestHandler.handleRequest(JsonRequestHandler.java:161)ntat org.jolokia.backend.MBeanServerHandler

我尝试通过添加 jmx 子系统来独立启用 jmx,如下所示:

<subsystem xmlns="urn:jboss:domain:jmx:1.3">
<remoting-connector use-management-endpoint="false"/>
</subsystem>

<connector socket-binding="jmx-remote" name="jmx-remote-connector" security-    realm="ApplicationRealm"/>

<socket-binding name="jmx-remote" port="${jboss.jmx.port:7909}" fixed-port="false"/>

但它仍然不起作用。有关更正我的方法或替代方法的任何帮助将不胜感激。

如果*QueueName*包含/则需要使用!/进行转义。 例如,jms/inputq必须转换为jms!/inputq

如果要避免转义,可以使用查询参数q。然后,网址最终看起来像/jolokia?p=/read/....

有关转义的详细信息,请参阅 https://jolokia.org/reference/html/protocol.html

相关内容

  • 没有找到相关文章

最新更新