使用activemq jms作为队列机制,我想监视我的队列,例如队列的大小。我正在使用Jolokia作为在JMX上执行休息请求的桥梁。
在wildfly中配置队列并且工作正常:
<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>
我在部署时在wildfly上部署了Jolokia war文件,以下url为我提供了一个属性列表:
localhost:8080/jolokia/list
现在我想阅读有关我的队列的信息,所以我使用以下休息请求:
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 attributes\n\tat org.jolokia.handler.ReadHandler.searchMBeans(ReadHandler.java:160)\n\tat org.jolokia.handler.ReadHandler.fetchAttributesForMBeanPattern(ReadHandler.java:126)\n\tat org.jolokia.handler.ReadHandler.doHandleRequest(ReadHandler.java:116)\n\tat org.jolokia.handler.ReadHandler.doHandleRequest(ReadHandler.java:37)\n\tat org.jolokia.handler.JsonRequestHandler.handleRequest(JsonRequestHandler.java:161)\n\tat 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"/>
但它仍然无效。关于我的方法或替代方法的更正的任何帮助将不胜感激。
答案 0 :(得分:1)
如果*QueueName*
包含/
,则需要使用!/
转义。例如,jms/inputq
必须转换为jms!/inputq
。
如果您想避免转义,可以使用查询参数q
。然后,网址最终看起来像/jolokia?p=/read/...
。
有关转义的详细信息,请参阅https://jolokia.org/reference/html/protocol.html