zk(Zookeeper)实现分布式锁

Zookeeper实现分布式锁

1,zk中锁的种类:

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

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

2,zk如何上读锁

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

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

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

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

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

3,zk如何上写锁

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

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

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

如果是则上锁成功

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

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

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

相关推荐
AI攻城狮20 小时前
RAG Chunking 为什么这么难?5 大挑战 + 最佳实践指南
人工智能·云原生·aigc
回家路上绕了弯2 天前
深入解析Agent Subagent架构:原理、协同逻辑与实战落地指南
分布式·后端
哈里谢顿3 天前
Kubernetes Operator核心概念、实现原理和实战开发
云原生
阿里云云原生3 天前
你的 OpenClaw 真的在受控运行吗?
云原生
阿里云云原生3 天前
5 分钟零代码改造,让 Go 应用自动获得全链路可观测能力
云原生·go
Shanyoufusu123 天前
RKE2 单节点集群安装 Rancher+ 私有镜像仓库搭建 完整教程
云原生
阿里云云原生3 天前
Dify 官方上架 Higress 插件,轻松接入 AI 网关访问模型服务
云原生
初次攀爬者3 天前
Kafka + ZooKeeper架构基础介绍
后端·zookeeper·kafka
AI攻城狮3 天前
OpenClaw Session 管理完全指南:Context 压缩、重置与持久化
人工智能·云原生·aigc
阿里云云原生7 天前
阿里云获评 Agentic AI 开发平台领导者,函数计算 AgentRun 赢下关键分!
云原生