zk(Zookeeper)实现分布式锁

Zookeeper实现分布式锁

1,zk中锁的种类:

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

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

2,zk如何上读锁

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

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

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

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

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

3,zk如何上写锁

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

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

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

如果是则上锁成功

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

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

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

相关推荐
你总是一副不开心的样子(´ . .̫ .3 小时前
消息队列Kafka
分布式·kafka
沐浴露z3 小时前
Kafka入门:基础架构讲解,安装与使用
java·分布式·kafka
wu~9706 小时前
Kafka底层解析:可靠性与高性能原理
分布式·kafka·操作系统
兜兜风d'6 小时前
RabbitMQ 发送方确认机制详解
spring boot·分布式·rabbitmq·java-rabbitmq·1024程序员节
也许是_7 小时前
Spring Boot 3.X推荐Micrometer Tracing 分布式链路追踪
spring boot·分布式·后端
兜兜风d'10 小时前
RabbitMQ 高级特性:消息确认机制详解
spring boot·分布式·rabbitmq·java-rabbitmq·1024程序员节
丈剑走天涯10 小时前
k8s etcd服务安装维护
云原生·etcd·devops·1024程序员节
周杰伦_Jay10 小时前
【Elasticsearch 全解析】分布式搜索引擎的原理、实践与优化
大数据·分布式·elasticsearch·架构·开源·1024程序员节
青0721松10 小时前
千云低代码平台ETMS-k8s实施部署
低代码·云原生·容器
睡不醒的猪儿13 小时前
k8s部署自动化工具jenkins
云原生·kubernetes·自动化·jenkins