Rabbitmq消息重复消费

1、消息何时会重复消费

自动提交模式时

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

手动提交模式

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

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

2.解决方案:

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

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

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

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

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

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

相关推荐
AKAMAI1 天前
分布式边缘推理正在改变一切
人工智能·分布式·云计算
慧一居士1 天前
xxl-job服务搭建,以及 springboot 集成xxl-job 项目完整步骤示例
分布式·中间件
2501_941822751 天前
从API网关到统一流量治理的互联网工程语法实践与多语言探索
rabbitmq·memcached
oMcLin1 天前
如何在 Ubuntu 22.04 服务器上实现分布式数据库 Cassandra 集群,优化数据一致性与写入吞吐量
服务器·分布式·ubuntu
2501_941882481 天前
互联网分布式系统中的性能优化工程实践与多语言示例随笔分享
kafka·rabbitmq
2501_941871451 天前
从接口限流到全链路流控的互联网工程语法构建与多语言实践分享
kafka·rabbitmq
马达加斯加D1 天前
系统设计 --- 使用消息队列解决分布式事务
分布式
2501_941865631 天前
从微服务链路追踪到全链路可观测的互联网工程语法实践与多语言探索
rabbitmq·memcached
遇见火星1 天前
RabbitMQ 高可用:HAProxy 负载均衡实战指南
分布式·消息队列·rabbitmq·负载均衡·haproxy
2501_941804321 天前
在东京智能地铁场景中构建实时列车调度与高并发乘客流数据分析平台的工程设计实践经验分享
rabbitmq·memcached