使用 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