【发布时间】:2022-01-19 15:04:53
【问题描述】:
我需要记录消息离开 ActiveMQs 队列的时间。 我有Q1,消费者是通过activemq-ra.rar在Jboss服务器上的java应用程序。
是否可以使用 Camel(包含在 ActiveMQ 中)拦截器来做到这一点? 我不是程序员,所以 XML DSL 的解决方案会很完美。
任何帮助将不胜感激。谢谢。
【问题讨论】:
标签: apache-camel activemq interceptor
我需要记录消息离开 ActiveMQs 队列的时间。 我有Q1,消费者是通过activemq-ra.rar在Jboss服务器上的java应用程序。
是否可以使用 Camel(包含在 ActiveMQ 中)拦截器来做到这一点? 我不是程序员,所以 XML DSL 的解决方案会很完美。
任何帮助将不胜感激。谢谢。
【问题讨论】:
标签: apache-camel activemq interceptor
查看日志代理插件。它可以将信息输出到日志中,然后您可以使用它来构建指标。
【讨论】:
使用advisoryForConsumed 并将建议消息转发到队列为我解决了这个问题。
在activemq.xml中:
<destinationPolicy>
<policyMap>
<policyEntries>
<policyEntry queue="Q1" advisoryForConsumed="true"/>
</policyEntries>
</policyMap>
</destinationPolicy>
然后将 ActiveMQ.Advisory.MessageConsumed.Queue.Q1 转发到另一个队列 AvisoryConsumed。
<destinationInterceptors>
<virtualDestinationInterceptor>
<virtualDestinations>
<compositeTopic name="ActiveMQ.Advisory.MessageConsumed.Queue.Q1" >
<forwardTo><queue physicalName="AvisoryConsumed" /> </forwardTo>
</compositeTopic>
</virtualDestinations>
</virtualDestinationInterceptor>
那么当一条消息被消费时,AvisoryConsumed 中就会有一条带有 brokerOutTime 的消息和原始消息的属性。
【讨论】: