RabbitMQ---如何保证MQ幂等性?

保证MQ幂等性通常是指保证消费者消费消息的幂等性。

1、使用数据库的唯一约束去控制。

添加唯一索引保证添加数据的幂等性。例如,对于订单处理场景,将订单号设置为唯一约束。当重复插入具有相同订单号的订单记录时,数据库会抛出异常,从而保证幂等性

2、使用token机制

总结:发送消息时给消息指定一个唯一的ID,发送消息时将消息ID写入Redis,消费时根据消息ID查询Redis判断是否已经消费,如果已经消费则不再消费。

如果是direct模式:

一个队列对应一个消费者,那不存在重复消费的问题;如果是一个队列对应多个消费者,那消费者会通过轮询来消费,也不会存在重复消费的问题;

如果是topic或者广播模式:

一个队列对应了多个消费者,且消费者会同时收到消息,那就会出现重复消费的问题,如果我们不希望出现重复消费,我们可以给消息加一个唯一id,i到red.png](https://img-blog.csdnimg.cn/img_convert/fc4db340f2555faef0d59f0ed03e0消息消费成功后就,当字符加过redis里面去这里我们可以用red的set类型,然后每次消费之前先看看redis里面有没有该id;

3、使用布隆过滤器

拿到一个消息之后在布隆过滤器中进行判断,如果存在,就不消费;如果不存在,就映射到布隆过滤器中,因为布隆过滤器存在误判的可能性,所以我个人认为可以结合数据库约束来配合使用,即布隆过滤器误判的消息给到数据库,因为误判的消息总量是很小的,所以不会给数据库带来太大的压力。所以布隆过滤器结合数据库约束可以保证消息的幂等性

相关推荐
huangdong_6 小时前
电商平台图片URL原图转换技术深度解析:从缩略图到高清原图的完整方案
java·后端·spring
記億揺晃着的那天6 小时前
Java 调用外部 Go 程序的实践:ProcessBuilder 在生产环境中的应用
java·golang·processbuilder
JAVA面经实录9176 小时前
Java 数据结构与算法 (终极完整学习文档)
java·数据结构·算法
JAVA面经实录9177 小时前
操作系统面试题
java·服务器·数据库·计算机网络·面试
一杯奶茶¥8 小时前
基于springboot的失物招领管理系统带万字文档 校园失物招领管理系统 失物认领管理系统java springboot vue
java·vue.js·spring boot·java项目
不能只会打代码8 小时前
边缘视频分析平台的架构设计与性能优化——从750ms到190ms的调优之路
java·spring boot·redis·性能优化·边缘计算·物联网竞赛
小刘|8 小时前
Spring AI Alibaba 集成和风天气 API 实战
java·服务器·前端
KANGBboy8 小时前
java知识五(继承)
java·开发语言
AI人工智能+电脑小能手8 小时前
【大白话说Java面试题 第117题】【并发篇】第17题:线程有几种状态,之间如何转换?
java·开发语言·面试
DIY源码阁8 小时前
JavaSwing饮品管理系统 - MySQL版
java·数据库·mysql·eclipse