消息队列如何保证幂等【方案篇】
创作时间:
作者:
@小白创作中心
消息队列如何保证幂等【方案篇】
引用
CSDN
1.
https://m.blog.csdn.net/weixin_44591233/article/details/139687430
在分布式系统中,消息队列的幂等性问题是一个常见的挑战。本文将深入探讨如何通过分布式锁、Token令牌和去重表等技术手段,有效防止消息重复提交和重复消费,保障系统的稳定性和数据一致性。
幂等的类型
在讨论解决方案之前,我们先明确幂等性的两种主要类型:
接口幂等(防止消息重复提交):防止接口重复提交消息
Example:用户在付款的时候,同时点击了多次付款按钮,后端处理了多次相同的扣款请求,结果导致账户被扣了多次钱
消息队列幂等(防止消息重复消费):保障消息队列客户端对相同的消息仅消费一次
通常情况下,我们认为消息中间件是一个可靠的组件。这里的可靠性指的是,只要消息被成功投递到了消息中间件,它就不会丢失,至少能够被消费者成功消费一次。这是消息中间件最基本的特性之一,也就是我们通常所说的“AT LEAST ONCE”,即消息至少会被成功消费一遍。
造成问题也很明显,如果消息中间件迟迟收不到客户端消息确认信号,就会让客户端再次消费消息。
怎么解决幂等问题
针对上述两种幂等性问题,我们可以采用以下解决方案:
分布式锁(避免用户重复访问业务接口)
分布式锁是一种常见的防止重复提交的解决方案。具体实现步骤如下:
- 当用户提交请求时,服务器端生成一个唯一的标识。
- 在处理用户请求之前,服务器尝试获取一个分布式锁。
- 如果成功获取到分布式锁,那么则执行接下来的正常业务逻辑流程。因为锁已经被获取,这样可以确保其他请求无法使用相同的标识,避免重复处理。
- 在请求处理完成后,服务器需要释放分布式锁。
Token令牌
Token令牌机制也是一种有效的防止重复操作的方法。具体流程如下:
- 客户端在第一次调用业务请求之前会发送一个获取 Token 的请求。
- 服务端会生成一个全局唯一的 ID 作为 Token,并将其保存在 Redis 中,同时将该 ID 返回给客户端。
- 在客户端进行第二次业务请求时,必须携带这个 Token,服务端会验证这个 Token,如果验证成功,则执行业务逻辑并从 Redis 中删除该 Token。
- 如果验证失败,说明 Redis 中已经没有对应的 Token,表示重复操作,服务端会直接返回指定的结果给客户端。
需要注意的是,这种方法需要两次请求才能完成一次业务操作。
去重表
去重表是指使用 Redis 或者 MySQL 记录已经处理过的请求或操作,以防止重复执行。大部分场景下,大家会使用 Redis 作为去重组件实现。
具体实现步骤如下:
- 当客户端发送请求时,服务端会先查询 Redis 去重表来检查该请求是否已经被处理过。
- 如果在存在对应的记录,表示请求已经执行过,服务端可以直接返回,而不再执行重复操作。
- 如果不存在对应的记录,表示请求是新的,服务端会执行相应的业务逻辑,并在处理完成后将请求的唯一标识(如请求 ID 或标识)添加到 Redis 去重表中,以便后续的重复请求可以被正确识别和处理。
另外,如果消息在消费中抛出异常,消息会触发延迟消费,将消息发送到重试队列(RETRY TOPIC)。
具体流程说明:
- 第一次消费时,会先插入一个唯一标识 Key 到 Redis 中,此时必然能插入成功,此时 key 只是插入状态,还没有更新为消费成功状态。
- 等到业务消费成功后,再将插入的 key 更新为消费成功状态。
- 如果重复发送了消息,Redis中已经存在了对应的key,但是这个key有可能是正在消费状态,也有可能是消费成功状态。这两种情况下都会插入失败,于是接着判断key对应的状态,如果key是消费成功状态,那么直接返回。如果key是正在消费状态,那么将消息发送到重试队列中,等待其他的消费者线程完成消费。
热门推荐
使用操纵开发语言的生成式AI自动开发前沿的设备和系统
“跨性别”给奥林匹克出了道难题
七大芳香树木来袭,你的鼻子准备好了吗?
做骨髓穿刺对身体有害吗
劳动合同要加盖私章吗?法律实务中的关键问题解析
属牛人今日运势详解:综合、爱情、事业、财富全方位解析
好枪的三大核心要求:无卡壳、弹药兼容性强、维护简便
中式园林规划这几个设计手法你都知道吗?
园林植物造景的基本原则
不管亲戚之间关系好不好,随礼时,要注意这3条规矩,非常重要
《哈利·波特》重映,唤醒你心中的魔法世界
“充电一小时,工作两小时” 人形机器人续航问题何解?高性能电池正在开发
狗腿脱臼症状全解析(狗狗腿部异常)
白日依山尽,黄河入海流的意思是什么 创作背景及影响有哪些
白日依山尽,黄河入海流的意思是什么 创作背景及影响有哪些
梅花易数测吉凶怎么算(梅花易数吉凶判断)
从嫦娥一号到嫦娥五号,一文回顾中国的探月之旅!
去平遥古城的交通路线
去平遥古城的交通路线
提升孩子网络安全意识与自我保护能力的策略
GaussDB高安全—端侧密钥管理
广州南站至广州站乘坐2号线地铁所需时长是多少?
应对口干舌燥的有效方法与健康提示,助你提升生活质量
X荧光光谱仪如何建立正确的标准样品?
如何编写详细的软件部署说明以确保顺利上线?
吉他选购完全指南:从入门到进阶,手把手教你挑选适合的吉他
监事会信息宣传:提升企业透明度和信任度的有效途径
腹泻引起的血压低怎么办
2025年度五项大赛,哪个对孙颖莎最关键?总决赛垫底,第一却很意外
12次摘WTT桂冠,几乎等同于其他高手女单金牌之和,孙颖莎太牛了