图解分析:基于setnx的分布式锁有什么缺陷

spring boot 和redis集成

图解分析:基于setnx的分布式锁有什么缺陷?

基于setnx的分布式锁存在单点风险,如果存储的分布式锁key挂掉的话,就可能存在丢锁的风险。一旦丢锁,就会造成多个客户端同时握有锁,从而导致分布式锁失败。
具体如下:
在这里插入图片描述

  1. 客户端A 从master拿到锁lock01
  2. master正要把lock01同步(Redis的主从同步通常是异步的)给slave时,突然宕机了,导致lock01没同步给slave
  3. 主从切换,slave节点被晋级为master节点
  4. 客户端B到master拿lock01照样能拿到。这样必将导致同一把锁被多人使用。

以上这种情况,无论Redis的部署架构是单机模式、主从模式、哨兵模式还是集群模式,都存在这种风险。
那怎么解决呢?Redis 之父 antirez 提出了 redisson的redlock算法 可以解决这个问题。

redlock算法的设计原理

redlock为了解决CAP的cp,数据一致性,采用有n个redis节点,n为奇数,上图我们有3个master,这3个master完全独立,不是主从复制或集群。(这里和zookeeper类似,熟悉zookeeper的同学或听过我课程的同学都能懂)

为什么N必须为奇数呢?
在回答这个问题前,先给大家讲一下什么是容错?
即在集群环境中,失败实例多少个我还是可以容忍,即系统的CP还是数据一致的。
例如
在集群环境中,redis失败1台,我还是可以容忍, 2n+1=2+1=3, 故部署奇数为3台redis 实例, 所以在3台的集群中,死掉1台,剩下2台集群正常工作。
在集群环境中,redis失败2台,我还是可以容忍, 2n+1=2*2+1=5,故部署奇数为5台redis 实例, 所以在5台的集群中,死掉2台,剩下3台集群正常工作。

那为什么是奇数,不是偶数?
因为有一个原则:使用资源最少,产生最大的容错。
例如
在集群环境中,redis失败1台,我还是可以容忍;奇数= 2n+1=2+1=3,偶数=2n+2=4
在集群环境中,redis失败2台,我还是可以容忍;奇数= 2n+1=2*2+1=5,偶数=2n+2=6
以上容忍度一样,但是部署的实例偶数比奇数多了一台。

  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis自带分布式锁是基于Redis的普通命令实现的。为了更好地理解Redis自带分布式锁,我们需要先了解与分布式锁相关的普通Redis命令。只有充分了解这些命令,才能更好地理解高级的Redis分布式锁实现,因为高级的分布式锁实现完全基于普通Redis命令。 在Redis中,分布式锁实现原理其实很简单,它基于RedLock思想。具体实现过程是遍历所有的Redis客户端,然后依次对它们进行加锁操作。最后统计成功的次数来判断是否加锁成功。 需要注意的是,Redis自带的分布式锁也有性能瓶颈问题。在高并发情况下,如果同时有多个客户端请求加锁,可能会导致性能下降。为了解决这个问题,可以采用Redis分段锁的方式,将锁分为多个段,每个段有自己的锁。这样可以提高并发性能。 除了Redis自带的分布式锁分布式锁实现还有其他方式,比如基于文件锁、数据库锁、以及基于ZooKeeper的分布式锁等。具体选择哪种方式取决于具体的应用场景和需求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Redis分布式锁图解 - 秒懂 - 史上最全)](https://blog.csdn.net/crazymakercircle/article/details/116425814)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值