南宁会员网站制作,广州市照明建设管理中心网站,wordpress5无法创建目录,双语网站建设一、应答模式
RabbitMQ 中的消息应答模式主要包括两种#xff1a;自动应答#xff08;Automatic Acknowledgement#xff09;和手动应答#xff08;Manual Acknowledgement#xff09;。#xff08;一般交换机发送消息#xff0c;RabbitMQ只有在接收到消费者的确认后才…一、应答模式
RabbitMQ 中的消息应答模式主要包括两种自动应答Automatic Acknowledgement和手动应答Manual Acknowledgement。一般交换机发送消息RabbitMQ只有在接收到消费者的确认后才会将消息从队列中删除。在队列发送消息时首先会先复制一份给消费者在收到消费者的确认消息后队列才会将队列中的消息删除。 1、自动应答
不在乎消费者对消息处理是否成功都会告诉队列删除消息。如果处理消息失败实现自动补偿队列投递过去 重新处理。
2、手动应答 在手动应答模式下消费者在接收到消息后并不会立即向RabbitMQ确认消息已处理完毕。消费者需要显式调用basicAck方法来确认消息处理完成RabbitMQ只有在接收到消费者的确认后才会将消息从队列中删除。 采用手动应答可以提高消息的可靠性即使消费者在处理消息过程中出现问题只要未发送ack确认RabbitMQ会在重新连接后再次将消息发送给该消费者。 如果消费者在处理消息前断开了连接或者在处理消息期间抛出了未捕获的异常RabbitMQ会认为消息未被正确处理从而重新排队消息确保消息至少会被消费一次at least once delivery。 二、SpringBoot如何实现两种应答。
1、自动应答
在Spring Boot的配置文件application.properties中对于RabbitMQ监听器设置自动应答模式默认就是自动应答
可以在配置文件中设置自动应答
# 自动应答模式
spring.rabbitmq.listener.simple.acknowledge-mode auto
Component
public class AutoAcknowledgementConsumer {RabbitListener(queues yourQueue)public void consumeMessage(String message, Message amqpMessage) {// 处理消息...// 框架会在方法执行完成后自动发送ack确认消息}
} 自动应答的效果开启自动应答如果出现异常消费者没有返回确认信息交换机就会不停发送消息。 会不停的发送请求 2、 手动应答
首先同样在配置文件中启用手动应答模式
# 手动应答模式
spring.rabbitmq.listener.simple.acknowledge-mode manual RabbitListener(queues direct_01)public void receiveMessage(Ordering ordering, Message message, Channel channel) throws IOException {long deliveryTag message.getMessageProperties().getDeliveryTag();System.out.println(消费者434接收到消息 ordering);try {// 处理成功手动发送ack确认yesint i 5 / 0;channel.basicAck(message.getMessageProperties().getDeliveryTag(), false);} catch (Exception e) {// 处理失败可以选择重试或拒绝消息basicNack或basicRejectchannel.basicNack(deliveryTag, false, false); // b表示是否批量b1表示是否并重新入队,选择不重新入队后消息便会丢失}}
3.如何解决死循环重试机制 #应答模式 手动应答需要开发者手动应答
spring.rabbitmq.listener.simple.acknowledge-modeAUTO#批量预抓取数量,提高执行效率
spring.rabbitmq.listener.simple.prefetch 10
#开启消费者重试机制
spring.rabbitmq.listener.simple.retry.enabled true
#重试的最大次数
spring.rabbitmq.listener.simple.retry.max-attempts 6
#重试间隔时间
spring.rabbitmq.listener.simple.retry.initial-interval 3000
#重试间隔倍数默认值是1
spring.rabbitmq.listener.simple.retry.multiplier 2
#最大间隔时间默认值是10s
spring.rabbitmq.listener.simple.retry.max-interval 15000 四、SimpleMessageListenerContainer和DirectMessageListenerContainer区别
SimpleMessageListenerContainer和DirectMessageListenerContainer都是Spring AMQP提供的消息监听容器它们之间的区别在于 SimpleMessageListenerContainer是基于AMQP协议的而DirectMessageListenerContainer是基于RabbitMQ的因此SimpleMessageListenerContainer可以用于其他的AMQP实现而DirectMessageListenerContainer只能用于RabbitMQ。 SimpleMessageListenerContainer支持订阅多个队列可以使用通配符等方式进行配置而DirectMessageListenerContainer只能订阅一个队列。 SimpleMessageListenerContainer支持自动声明队列和绑定而DirectMessageListenerContainer需要手动声明和绑定队列。 SimpleMessageListenerContainer支持多线程处理消息而DirectMessageListenerContainer只能单线程处理消息。
因此如果需要监听多个队列或者使用其他的AMQP实现可以选择SimpleMessageListenerContainer如果只需要监听一个队列并且使用RabbitMQ可以选择DirectMessageListenerContainer。