Rabbitmq消息重复消费

1、消息何时会重复消费

自动提交模式时

消费者进行处理后,会给队列发送一个ack(参考上一篇的消息丢失),但是这个ack在中途丢失了,导致队列以为消费者没有成功消费。所以就不会删除这个消息,会进行重新消费。

手动提交模式

用户手动提交后,ack丢失,和上文一致。

接收到消息并处理接触了,此时消费者挂了,来不及发手动提交,发ack。

2.解决方案:

造成上面的原因只要还是网络问题、以及消费者宕机。这种是无法避免的。最多就是绕过这个问题。即:如果消费端收到两条一样的消息,应该怎样处理?

2.1 消费端处理消息的业务逻辑保持幂等性。

  • 比如你拿个数据要写库,先根据主键查一下,如果这数据有了,就别插入了,update 一下。
  • 比如你是写 Redis,那没问题了,反正每次都是 set,天然幂等性。

2.2 消费者用消息日志保证幂等

利用一张日志表来记录已经处理成功的消息的 ID,如果新到的消息 ID 已经在日志表中,那么就不再处理这条消息。

注意:此时需要保证每个消息都有唯一的id。 ​

相关推荐
ZePingPingZe1 小时前
分布式、Spring Boot微服务、垂直拆分、水平拆分、分库分表详解及关系梳理
分布式·架构
Blossom.1183 小时前
RLHF的“炼狱“突围:从PPO到DPO的工业级对齐实战
大数据·人工智能·分布式·python·算法·机器学习·边缘计算
2501_941822757 小时前
5G技术:引领智能时代的革命性变革
rabbitmq
2501_941149508 小时前
物联网在智能城市建设中的应用:打破边界,连接未来
rabbitmq
2501_941149508 小时前
5G技术赋能智能城市:连接未来的数字化基础设施
rabbitmq
小坏讲微服务9 小时前
Spring Cloud Alibaba整合 Kafka 的完整实现
分布式·spring cloud·kafka·消息队列·springboot·linq
zl97989910 小时前
RabbitMQ-延迟队列
分布式·rabbitmq
源码梦想家11 小时前
云计算与边缘计算:未来数字化转型的关键驱动力
rabbitmq
-大头.11 小时前
深入解析ZooKeeper核心机制
分布式·zookeeper·wpf
2501_9411481514 小时前
区块链技术与未来金融:去中心化的革命
rabbitmq