2

我是rabbitmq的新手,正在尝试以下场景

--> 生产者发送消息
--> 消费者接收消息
-- 执行我自己的逻辑

如果逻辑失败 - 重新排队

--> 如果消费者失败(机器宕机),则重新排队消息

我已经使用 Spring rabbitTemplate 实现了基本的发送者

rabbitTemplate.convertAndSend(.....);

对于消费者,我实现了一个消息监听器

public class CustomMessageListener implements MessageListener {
@Override
    public void onMessage(Message message) {
       //** my own logic**
   }
}

并通过弹簧将其添加到容器中

  <bean id="aListener" class="com.sample.CustomMessageListener" autowire="byName"/>

 <rabbit:listener-container id="myListenerContainer" connection-factory="connectionFactory"  acknowledge="auto" prefetch="750" concurrency="5" >
    <rabbit:listener ref="aListener" queues="reportQueue"/>
</rabbit:listener-container>

直到这部分它工作正常。

现在如果在监听器中提到的**我自己的逻辑**失败。我想重新排队消息。我该如何实现这一点。从我浏览过的博客来看,returnedMessage 似乎需要被覆盖。但我不确定如何通过监听器来完成。

4

1 回答 1

4

使用acknowledge="auto",直到侦听器正常退出,消息才会被确认,因此您无需做任何额外的事情;如果您的侦听器抛出异常或服务器崩溃,则消息将保留在队列中。

于 2015-07-08T12:40:57.430 回答