基于Zookeeper的分布式锁

分布式锁的介绍

在Java的多线程部分,我们知道如果在单个jvm进程中,多个线程之间同时访问一个资源,此时会有多线程的安全问题。为了解决这个线程安全的问题,我们可以使⽤"锁"来实现。但是,多个jvm进程之间如果同时访问一个资源呢?此时就需要一种更加高级的锁机制来处理种跨JVM进程之间的资源安全问题,这就是分布式锁。

分布式锁的分类

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

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

ZooKeeper分布式锁的优点

  • Zookeeper临时顺序节点的递增有序性,可以确保锁的公平
  • ZooKeeper的节点监听机制,能避免羊群效应

ZooKeeper分布式锁的实现

读锁的实现

  1. zk里有一把锁,这个锁就是zk上的一个节点locak-node。
  2. 在"locak-node"这个锁节点下,创建一个临时顺序节点,节点数据是read,表示读锁,这个顺序节点有zk内部自行维护的一个节点序号
  3. 获取锁节点下序列化比自己小的所有节点
  4. 判断上一个节点是不是读锁。 如果是的话,上锁成功;如果不是的话,则上锁失败,为上一个节点设置监听,阻塞等待。

写锁的实现

  1. zk里有一把锁,这个锁就是zk上的一个节点locak-node。
  2. 在"locak-node"这个锁节点下,创建一个临时顺序节点,节点数据是write,表示写锁,这个顺序节点有zk内部自行维护的一个节点序号
  3. 获取锁节点下所有节点
  4. 判断自己是不是序列化最小的一个节点。 如果是的话,上锁成功;如果不是的话,则上锁失败,为上一个节点设置监听,阻塞等待。
相关推荐
张忠琳4 小时前
【client-go v0.36.1】WorkQueue 深度分析(下篇)— 限流队列、限流器、指标、并行化
云原生·kubernetes·informer·workqueue·client-go
WyCAGy8ij5 小时前
Redis 分布式锁进阶第四篇讲解
数据库·redis·分布式
张忠琳6 小时前
【client-go v0.36.1】WorkQueue 深度分析(上篇)— 模块定位、结构、基础队列与延迟队列
云原生·kubernetes·informer·workqueue·client-go
jieyucx6 小时前
站在云原生高并发天花板:拆解 Go 语言 GMP 模型与 I/O 多路复用的神级配合
开发语言·云原生·golang
MrJson-架构师6 小时前
AgentScope Java 2.0:打造分布式、企业级智能体底座
java·开发语言·分布式
张忠琳6 小时前
【client-go v0.36.1】tools/cache 深度分析(上篇)— 模块定位、整体结构、接口与依赖关系
云原生·kubernetes·cache·informer·client-go
先跑起来再说6 小时前
Go 排行榜系统的工程化实现:分布式锁、快照表与定时刷新
分布式·go·gin
张忠琳6 小时前
【client-go v0.36.1】(Reflector Part 1)Reflector 超深度分析 — 模块定位、整体结构、接口与依赖
云原生·kubernetes·informer·client-go·reflector
Demon1_Coder7 小时前
Day4-微服务-Seata
微服务·云原生·架构
ACP广源盛139246256737 小时前
GSV2231 三屏显示扩展芯片@ACP#RTX Spark AI 终端多屏协作专属解决方案
大数据·人工智能·分布式·信息可视化·spark·电脑·音视频