分布式锁

Posted shizhuoping

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了分布式锁相关的知识,希望对你有一定的参考价值。

分布式锁

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

基本指令

加锁指令:setnx lock 目标 true

移除锁指令:del lock 目标

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

expire lock 目标 5(5秒过期)

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

set lock 目标 true ex 5 nx

加锁失败

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

集群中分布式锁的风险

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

以上是关于分布式锁的主要内容,如果未能解决你的问题,请参考以下文章

Redis实现分布式锁与Zookeeper实现分布式锁区别

分布式锁,及Redis实现分布式锁

分布式锁

高并发架构系列:什么是分布式锁?Redis实现分布式锁详解

Redisson分布式锁设计方案

Redis | 黑马点评 + 思维导图分布式锁