Rabbitmq消息重复消费

1、消息何时会重复消费

自动提交模式时

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

手动提交模式

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

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

2.解决方案:

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

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

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

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

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

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

相关推荐
让我上个超影吧9 小时前
消息队列——RabbitMQ(高级)
java·rabbitmq
塔中妖11 小时前
Windows 安装 RabbitMQ 详细教程(含 Erlang 环境配置)
windows·rabbitmq·erlang
断手当码农11 小时前
Redis 实现分布式锁的三种方式
数据库·redis·分布式
初次攀爬者12 小时前
Redis分布式锁实现的三种方式-基于setnx,lua脚本和Redisson
redis·分布式·后端
业精于勤_荒于稀13 小时前
物流订单系统99.99%可用性全链路容灾体系落地操作手册
分布式
Ronin30513 小时前
信道管理模块和异步线程模块
开发语言·c++·rabbitmq·异步线程·信道管理
Asher050913 小时前
Hadoop核心技术与实战指南
大数据·hadoop·分布式
凉凉的知识库14 小时前
Go中的零值与空值,你搞懂了么?
分布式·面试·go
?Anita Zhang14 小时前
联邦学习实战:如何在分布式场景下构建隐私保护机器学习模型
人工智能·分布式·机器学习
tony36514 小时前
pytorch分布式训练解释
人工智能·pytorch·分布式