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、使用布隆过滤器

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

相关推荐
IT古董23 分钟前
【权限管理】Apache Shiro学习教程
java·apache·shiro·权限
风月歌25 分钟前
基于Spring Boot的海滨体育馆管理系统的设计与实现
java·spring boot·后端
ggdpzhk4 小时前
idea 编辑竖列:alt +shift+insert
java·ide·intellij-idea
hikktn5 小时前
Java 兼容读取WPS和Office图片,结合EasyExcel读取单元格信息
java·开发语言·wps
迪迦不喝可乐5 小时前
软考 高级 架构师 第十一章 面向对象分析 设计模式
java·设计模式
檀越剑指大厂5 小时前
【Java基础】使用Apache POI和Spring Boot实现Excel文件上传和解析功能
java·spring boot·apache
苹果酱05675 小时前
Golang的网络流量分配策略
java·spring boot·毕业设计·layui·课程设计
孑么6 小时前
GDPU Android移动应用 重点习题集
android·xml·java·okhttp·kotlin·android studio·webview
未命名冀7 小时前
微服务面试相关
java·微服务·面试
Heavydrink7 小时前
ajax与json
java·ajax·json