我异步监听了一个OpenMQ队列。如果我在消费消息的过程中出现异常,有没有办法让OpenMQ再次向我推送该消息?
@Bean
public JmsListenerContainerFactory jmsQueueListenerContainerFactory() {
DefaultJmsListenerContainerFactory jmsListenerContainerFactory = new DefaultJmsListenerContainerFactory();
jmsListenerContainerFactory.setConnectionFactory(connectionFactory());
jmsListenerContainerFactory.setPubSubDomain(false);
jmsListenerContainerFactory.setSessionAcknowledgeMode(Session.AUTO_ACKNOWLEDGE);
return jmsListenerContainerFactory;
}MessageConsumer receiver = session.createConsumer(destination);
receiver.setMessageListener(new MessageListener() {
public void onMessage(Message message) {
TextMessage text = (TextMessage) message;
System.out.println("Received message: " + message.getText());
//The connection timed out when saving the message to the database
repository.save(text);
}
});发布于 2020-03-15 04:45:24
它未被取消的原因是您已将确认模式设置为AUTO_ACKNOWLEDGE。
jmsListenerContainerFactory.setSessionAcknowledgeMode(Session.AUTO_ACKNOWLEDGE);将其更改为CLIENT_ACKNOWLEDGE,如下所示:
jmsListenerContainerFactory.setSessionAcknowledgeMode(Session.CLIENT_ACKNOWLEDGE);使用message.acknowledge()提交消息。
使用session.recover()取消该消息。
https://stackoverflow.com/questions/60630890
复制相似问题