解决数据一致性方案(库存问题)

本文探讨了如何利用Redis的多种方法(如HSET、LPUSh)结合队列处理库存,确保秒杀业务中数据一致性。通过在库存减少时发送事务消息通知数据库,以解决异步消息和扣减操作可能遇到的问题。
摘要由CSDN通过智能技术生成

解决数据一致性方案

本文只讲述原理,均为伪代码,具体实现还得小伙伴实现。

Redis

Redis中第一种库存存储方式
  1. hset(key,value,goods) == set(key,goods)
  2. 秒杀业务下单

代码:

		//查询商品
        goods = redis.get(key);
        //判断库存
        if (goods.getStockCount <= 0) {
   
            //已售馨
        } else {
   
            //减redis库存
            //下单业务
        }
问题:
在第一步执行,如果有多个线程一起进来,都会拿到相同数量库存,会出现超卖现象。
Redis中第二种方式
  1. hset(key,value,goods) == set(key,goods)
  2. 库存:hset(key, value, stockCount)
		//减库存
		Long result = redis.increment(key, value
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值