Redis18:分布式锁

分布式锁

多个系统要对一个key进行操作,最后操作key的顺序和预期的顺序不一致,此时就用分布式锁对一个目标加锁,使其他进程无法争到已经被占用的锁。

基本指令

加锁指令:setnx lock 目标 true

移除锁指令:del lock 目标

但是如果在加锁后执行出现异常终止导致没有移除锁,就会导致死锁,所以要给锁加一个自动释放时间:

expire lock 目标 5(5秒过期)

redis还提供了setnx和expire组合的原子指令,大大降低了风险:

set lock 目标 true ex 5 nx

加锁失败

加锁失败时可以直接抛出异常,提醒用户重试,或者sleep一会,但是信息多时不合适,也可以把任务放在延时队列中处理。

集群中分布式锁的风险

在集群中分布式锁可能有风险,当一个客户端在主节点申请了一把锁,然后主节点突然挂掉,从节点变为主节点,当锁信息还没有同步过去的时候,新的请求就有可能在新主节点加锁成功,出现两个客户端占用同一把锁的情况。此时可以使用redlock算法,但是它会让性能下降,运维负担加重。

原文地址:https://www.cnblogs.com/yinyunmoyi/p/11525900.html