[英]Spring AMQP (Rabbit) Listener goes in a loop in case of exception
@Bean
RabbitTemplate rabbitTemplate() {
RabbitTemplate template = new RabbitTemplate(rabbitConnectionFactory());
template.setMessageConverter(messageConverter);
template.setExchange(amqpProperties.getRabbitMqTopicExchangeName());
return template;
}
@Bean
@Conditional (OperationsCondition.class)
SimpleMessageListenerContainer opsMessageListenerContainer() {
return listenerContainer(amqpProperties.getRabbitMqOperationsQueue(),
amqpProperties.getInitialRabbitOperationsConsumerCount(),
amqpProperties.getMaximumRabbitOperationsConsumerCount(),
opsReceiver());
}
@Bean
@Conditional (OperationsCondition.class)
OperationsListener opsReceiver() {
return new OperationsListener();
}
private SimpleMessageListenerContainer listenerContainer(String queue,
int initConsumers,int maxConsumers, MessageListener listener)
{
SimpleMessageListenerContainer container = new SimpleMessageListenerContainer();
container.setConnectionFactory(rabbitConnectionFactory());
container.setQueueNames(queue);
container.setMessageListener(listener);
container.setConcurrentConsumers(initConsumers);
container.setMaxConcurrentConsumers(maxConsumers);
container.setMessageConverter(messageConverter);
return container;
}
消息監聽器是:
public class OperationsListener implements MessageListener
{
public static final Logger logger = Logger.getInstance(OperationsListener.class);
@Autowired (required=true)
private OperationsProcessor processor;
@Autowired (required=true)
private ObjectMapper objectMapper;
public void onMessage(Message message)
{
Jackson2JsonMessageConverter converter = new Jackson2JsonMessageConverter();
converter.setJsonObjectMapper(objectMapper);
OperationsMessage request = (OperationsMessage)converter.fromMessage(message);
processor.createMessage(request);
//This is throwing a JPA database exception
processor.createOperation(request);
}
}
processor.createOperation()因數據庫問題而拋出異常。 問題是消息監聽器進入循環並且消息不斷回來。
我的處理器類:
@Component
@Transactional (propagation = Propagation.REQUIRES_NEW)
public class OperationsProcessor
{
...............
public void createOperation(OperationsMessage message)
{
try
{
.............
.............
//this call throws exception.
opsRepo.create(operation,null);
}
catch (Exception e)
{
logger.error(e);
}
}
}
opsRepo.create拋出異常。 即使我正在捕捉錯誤,我希望春天amqp不再發送該消息。 不確定為什么同樣的消息不斷回來。
編輯:
我想我找到了一些關於如何處理這個問題的建議。 原因是春天在失敗時重新發生事件,這是默認的性質。 在這里和這里找到一個有用的線程。
為了確認您找到了什么,這在參考手冊“異常處理”一節中有明確說明 。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.