Redis怎么实现分布式锁

本文详细讨论了Redis中分布式锁的实现,包括setnx命令的使用,防止死锁的策略如设置过期时间和使用lua脚本,以及如何处理过期时间的动态调整。还提到Redis分布式锁无法保证绝对安全,尤其是在单机、主从或集群环境下可能存在的问题。此外,简要介绍了Redisson的实现,包括其阻塞唤醒机制和watchdog功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

怎么实现

1)setnx
如果一个key已经存在,设置失败,返回0;

2)防止死锁
设置过期时间 :lua脚本/redis2.8以后的ex命令

3)过期时间设置多久
如果锁住的代码还没执行完,锁已经过期了,那么其他线程又能获取锁,所以可以开启一个异步线程,如果当前线程还没释放锁,继续延长锁的过期时间;同时释放锁的时候判断key对应的value是不是自己设置的,如果是才删除,用lua脚本保证原子性;

绝对安全吗

redis实现的分布式锁无论如何也不能保证安全,假设现在是单机redis实现分布式锁,一个线程获取锁成功后,在还没释放锁之前,那个锁的可以还没持久化,那么redis重启后,锁就丢失了,无论是用rdb还是aof的always策略都会有这个问题;更别说在主从架构或者集群架构下的分布式锁,也会有类似的问题,所以redis的分布式锁实现的是ap架构。

redisson怎么实现的

1)获取不到锁,阻塞唤醒怎么设计的?
2)watchdog怎么实现的?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值