redis的高并发分布式锁

在高并发环境中,为了防止数据不一致,通常使用Redis实现分布式锁。为确保锁的正确释放,使用try-finally块并在锁上设置过期时间。然而,业务未完成时锁可能已过期,解决方案是引入锁续命机制。同时,每个锁应关联特定用户或线程ID以防止错误解锁。推荐使用redisson,它提供了安全且便捷的加锁、解锁功能。
摘要由CSDN通过智能技术生成

高并发情形下:
redis需要加锁
redis加了锁之后,需要解锁。
加锁和解锁之间,可能服务器出现问题,可以用try-fianlly来保证解锁。如果还没执行到finally的时候,系统就崩溃了,那么这个锁就永远锁住了,怎么处理?
所以我们需要给锁加一个过期的时间,防止出现锁加上去没有释放的情形。
如果加的锁,业务还没执行完成,过期时间时间到了,那么这个锁就失效了,怎么弄?增加一段锁续命的逻辑。
如果第一个加的锁,被后面的请求解锁了,怎么处理?给每个用户的请求加上自己的user或者加上自己的线程的id。
上面所有的操作都不是一行代码搞定的,如果代码之间出现异常,后面的逻辑不会走,怎么处理???可以使用redisson,redis官方推荐的,加锁和解锁都是非常的好用又安全。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值