RabbitMQ解决重复消费(幂等问题)思路

一、问题描述

        在使用秒杀的场景当中,使用下单操作的时候,调用第三方支付接口已经支付成功并且扣款了,但是一直订单页面一直没有显示出来,用户可能会尝试再度支付!如何解决用户重复消费的这个问题?

二、两个思路

        1、就是在设计业务数据库表格的时候,在mysql当中,将订单的id设置为主键,主键在表中本来就是唯一的,可以保障用户重复支付相同订单不会成功;

        2、使用redis的set数据类型,set当中的key都是唯一的,本身就可以实现幂等操作;

  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
解决RabbitMQ消息重复消费的方法有多种。一种方法是在消费消费消息成功后,在给MQ发送消息确认的时候出现网络异常或服务中断的情况下,MQ不会将发送的消息删除,而是会继续给消费者投递之前的消息,导致消费者接收到了两条一样的消息。为了解决这个问题,可以在消费者端使用等性来处理消息,即使接收到重复的消息,也能保证最终的结果是一致的。\[1\]\[2\] 另一种方法是在消费者监听消费消息时,使用消息的唯一标识来判断是否已经消费过该消息。可以在消费者端记录已经消费过的消息的标识,当接收到重复的消息时,先判断该消息的标识是否已经存在,如果存在则不进行消费,避免重复消费。\[3\] 除了以上两种方法,还可以使用消息的等性保证机制,即在消息的生产者端设置消息的唯一标识,并在消费者端进行等性校验,如果消息的唯一标识已经存在,则不进行消费。这样可以避免重复消费问题。 总之,解决RabbitMQ消息重复消费的方法包括使用等性处理消息、记录已经消费过的消息的标识以及使用消息的唯一标识进行等性校验等。根据具体的业务需求和场景,选择合适的方法来解决重复消费问题。 #### 引用[.reference_title] - *1* *2* *3* [RabbitMQ消息重复消费场景及解决方案](https://blog.csdn.net/chenping1993/article/details/114580954)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值