zk(Zookeeper)实现分布式锁

Zookeeper实现分布式锁

1,zk中锁的种类:

读锁:大家都可以读,要想上读锁的前提:之前的锁没有写锁

写锁:只有得到写锁的才能写。要想上写锁的前提是:之前没有任何锁

2,zk如何上读锁

创建一个临时序号节点,节点的数据是read,表示的是读锁

获取当前zk中序号比自己小的所有节点

判断最小节点是否是读锁:

如果不是读锁的话,则上锁失败,为最小节点设置监听 。阻塞等待,zk的watch机制会当最小节点发生变化时通知当前节点,于是再执行第二步的流程

如果时读锁的话,则上锁成功

3,zk如何上写锁

1, 创建一个临时序号节点,节点的数据时write,表示的是写锁

2, 获取zk中所有的子节点

3, 判断自己是否是最小节点:

如果是则上锁成功

不过不是,说明前面还有锁,则上锁失败,监听最小的节点,如果最小节点有变化则回到第二步

羊群效应: 如果用上述的上锁方式,只要有节点发生变化,则会触发其他节点的监听事件,这样的话zk的压力非常大 ----------可以调整成链式监听,解决这个问题

Curator(Zookeeper的客户端)实现读写锁

相关推荐
极限实验室2 小时前
APM(一):Skywalking 与 Easyearch 集成
数据库·云原生
Query*4 小时前
分布式消息队列kafka【五】—— kafka海量日志收集实战
分布式·kafka
serendipity_hky5 小时前
【SpringCloud | 第5篇】Seata分布式事务
分布式·后端·spring·spring cloud·seata·openfeign
ascarl20108 小时前
Kubernetes 环境 NFS 卡死问题排查与解决纪要
云原生·容器·kubernetes
阿里云云原生8 小时前
快速构建企业 AI 开放平台,HiMarket 重磅升级
云原生
lang201509289 小时前
Kafka元数据缓存机制深度解析
分布式·缓存·kafka
qq_3432470310 小时前
单机版认证kafka
数据库·分布式·kafka
武子康10 小时前
Java-199 JMS Queue/Topic 集群下如何避免重复消费:ActiveMQ 虚拟主题与交付语义梳理
java·分布式·消息队列·rabbitmq·activemq·mq·java-activemq
富士康质检员张全蛋11 小时前
zookeeper 常用命令之zkCli
zookeeper
源代码•宸11 小时前
分布式缓存-GO(简历写法、常见面试题)
服务器·开发语言·经验分享·分布式·后端·缓存·golang