mic*_*ele 2 activemq-classic jms message-queue dead-letter spring-jms
这是我的配置:
@Bean
ActiveMQConnectionFactory activeMQConnectionFactory() {
String url = this.environment.getProperty("jms.broker.url");
ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory();
connectionFactory.setBrokerURL(url);
connectionFactory.setRedeliveryPolicy(redeliveryPolicy());
return connectionFactory;
}
@Bean
public RedeliveryPolicy redeliveryPolicy() {
RedeliveryPolicy redeliveryPolicy = new RedeliveryPolicy();
redeliveryPolicy.setInitialRedeliveryDelay(500);
redeliveryPolicy.setBackOffMultiplier(2);
redeliveryPolicy.setUseExponentialBackOff(true);
redeliveryPolicy.setMaximumRedeliveries(5);
return redeliveryPolicy;
}
.....
Run Code Online (Sandbox Code Playgroud)
这是我的消费者:
@Service("msgConsumer")
public class MessageConsumer {
private static final String ORDER_RESPONSE_QUEUE = "thequeue.Q";
@JmsListener(destination = ORDER_RESPONSE_QUEUE, containerFactory = "jmsListenerContainerFactory")
public void receiveMessage(final Message<String> message) throws Exception {
MessageHeaders headers = message.getHeaders();
LOG.info("Application : headers received : {}", headers);
String response = message.getPayload();
LOG.info("Application : response received : {}",response);
if(response.equals("launch"))
throw new Exception("Error");
}
}
Run Code Online (Sandbox Code Playgroud)
所以我把一个带有payload =“launch”的消息放入队列中。
我想测试交易,如果有效负载等于“启动”,它会抛出异常。
因此,由于 redeliverypolicy,消费者尝试消费该消息 5 次。在 ActiveMq 队列列表中的第五个之后,我没有看到我发送的消息。
消息放在哪里?在死信队列中?我在哪里可以看到带有“启动”消息的死信队列?
谢谢。
ActiveMQ.DLQ- 请参阅此处的文档。
一旦消息的重新传递尝试超过为重新传递策略配置的最大重新传递次数,“Poison ACK”将发送回代理,让他知道该消息被视为毒丸。然后 Broker 接收消息并将其发送到死信队列,以便稍后对其进行分析。
ActiveMQ 中默认的死信队列称为 ActiveMQ.DLQ;所有无法传递的消息都将发送到此队列,这可能难以管理。因此,您可以在 activemq.xml 配置文件的目标策略映射中设置一个 individualDeadLetterStrategy,它允许您为给定的队列或主题指定特定的死信队列前缀。如果您愿意,您可以使用通配符应用此策略,以便所有队列都有自己的死信队列,如下面的示例所示。
可以在控制台看到DLQ;您可以像任何其他队列一样使用它。