zk(Zookeeper)实现分布式锁

Zookeeper实现分布式锁

1,zk中锁的种类:

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

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

2,zk如何上读锁

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

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

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

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

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

3,zk如何上写锁

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

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

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

如果是则上锁成功

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

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

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

相关推荐
逸Y 仙X1 分钟前
适合java程序员的Kafka消息中间件实战
分布式·中间件·kafka·消息中间件
LUCIAZZZ7 小时前
简单介绍分布式定时任务XXL-JOB
java·spring boot·分布式·spring·操作系统·定时任务
小白学大数据8 小时前
分布式爬虫去重:Python + Redis实现高效URL去重
开发语言·分布式·爬虫·python
一个天蝎座 白勺 程序猿11 小时前
Python爬虫(14)Python爬虫数据存储新范式:云原生NoSQL服务实战与运维成本革命
爬虫·python·云原生
灵雀云12 小时前
证券行业数字化转型:灵雀云架设云原生“数字高速路”
云原生·paas
AllData公司负责人13 小时前
【能力比对】K8S数据平台VS数据平台
云原生·容器·kubernetes
识途老码13 小时前
k8s部署OpenELB
云原生·容器·kubernetes·eip
搞不懂语言的程序员14 小时前
Kafka Consumer的auto.offset.reset参数有哪些配置?适用场景?
分布式·kafka
洋芋爱吃芋头14 小时前
hadoop中的序列化和反序列化(2)
大数据·hadoop·分布式
Super_man5418815 小时前
k8s之ingress解释以及k8s创建业务的流程定义
云原生·容器·kubernetes