Redisson分布式锁主从一致性问题

主从一致性问题是什么?

单机模式下,服务器宕机会造成严重的后果,因此企业实际开发中往往是多台服务器集群模式。集群模式下分为主节点和从节点,主节点负责写操作,如增删改,从节点负责读操作,从主节点中读取数据,因此数据主要存在主节点。

主从同步不可避免存在延迟,这就会导致当Java应用向主节点发送获取锁的请求,主节点接收请求后,锁的信息存储到主节点,此时主从之间还没来得及同步,主节点发生宕机,redis的哨兵发现主节点宕机后会在剩余的从节点选择一个作为新的主节点,但此时新的主节点没有之前的锁,即之前设置的锁已失效,当新的线程发来请求,又可以获取到锁,两个线程就可能发生并发的问题,这就是分布式锁主从一致性问题。

Redisson的multiLock原理

为了解决这个问题,redission提出来了MutiLock锁,使用这把锁咱们就不使用主从了,每个节点的地位都是一样的, 这把锁加锁的逻辑需要写入到每一个主丛节点上,只有所有的服务器都写入成功,此时才是加锁成功,假设现在某个节点挂了,那么它去获得锁的时候,只要有一个节点拿不到,都不能算是加锁成功,就保证了加锁的可靠性。

相关推荐
石榴树下的七彩鱼18 小时前
医疗票据OCR识别API实战:从医保结算单到结构化数据提取(附Python/Java示例)
java·人工智能·python·ocr·api·ocr识别·医疗票据识别
Cat_Rocky18 小时前
k8s-单Master集群部署(简练理解)
java·容器·kubernetes
C雨后彩虹18 小时前
投篮大赛问题
java·数据结构·算法·华为·面试
Hello eveybody18 小时前
介绍最大公因数和最小公约数(C++)
java·开发语言·c++
ckhcxy18 小时前
抽象类和接口
java·开发语言
Gerardisite18 小时前
私域运营新利器:RPA驱动外部群多模态互动
java·人工智能·python·微信·自动化
@小柯555m19 小时前
算法(字母异位词分组)
java·开发语言·算法·leetcode
Carsene19 小时前
开篇:我们距离理想的 Java SQL DSL 还有多远?
java·sql
敖正炀19 小时前
集合-List-LinkedList
java
AI人工智能+电脑小能手19 小时前
【大白话说Java面试题】【Java基础篇】第9题:HashMap根据key查询元素的时间复杂度是多少
java·开发语言·数据结构·后端·面试·哈希算法·哈希表