redis记录——分布式锁解析

场景:减库存

知识点:

setIfAbsent():设置值之前判断key是否存在,setIfAbsent(key,vlue,时长,时间类型)

         * setIfAbsent()是redis(setnx)在java中的用法

思路:

1.生成一个库存锁,把存库数量stock和库存的锁result同时放在redis中,更改存库数量时,先判断库存锁是否有效和存在。

2.如果库存锁存在返回一个错误提示

3.如果存库锁不存在,拿取库存数量执行具体代码逻辑

4.执行完毕后删除锁

5.整个业务逻辑用try包裹,删除锁放在finally里,保证都能释放锁

5.后续其他线程同样这样执行。

锁的设计:

1.clientId:标识本次方法执行的身份id

2.利用setIfAbsent()的特性,设置锁的key:lockKey,设置锁的value:clientId,设置锁的失效时间:30,设置时间类型:秒

具体代码实现:        

 缺陷:

身份验证和删除锁不是原子操作,如果在拿到锁并且身份验证通过后还没有删除锁时,jvm在锁失效的瞬间发生了gc(程序停顿了一瞬间)。一样会导致删除了别的线程的锁,出现多扣库存的情况

针对这种情况解决办法:可以启用一个监听线程,对锁进行续命(后续更新补充)

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值