2

这是我的配置:

@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;
}
.....

这是我的消费者:

@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");
    }
}

因此,我将有效负载 =“启动”的消息放入队列中。

我想测试事务,如果有效负载等于“启动”,它会抛出异常。

所以感谢 redeliverypolicy,消费者尝试消费消息 5 次。在 ActiveMq 队列列表中的第五个之后,我没有看到我发送的消息。

消息放在哪里?在死信队列中?在哪里可以看到带有“启动”消息的死信队列?

谢谢。

4

1 回答 1

5

ActiveMQ.DLQ- 请参阅此处的文档

一旦消息的重新传递尝试超过了为重新传递策略配置的最大重新传递,一个“毒 ACK”被发送回代理,让他知道该消息被认为是毒丸。然后,Broker 接收消息并将其发送到死信队列,以便稍后对其进行分析。

ActiveMQ 中默认的死信队列称为 ActiveMQ.DLQ;所有无法投递的消息都将发送到此队列,这可能很难管理。因此,您可以在 activemq.xml 配置文件的目标策略映射中设置 individualDeadLetterStrategy,它允许您为给定队列或主题指定特定的死信队列前缀。如果您愿意,可以使用通配符应用此策略,以便所有队列都有自己的死信队列,如下例所示。

可以在控制台看到DLQ;您可以像任何其他队列一样使用它。

于 2018-01-25T17:25:36.227 回答