基于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. 判断自己是不是序列化最小的一个节点。 如果是的话,上锁成功;如果不是的话,则上锁失败,为上一个节点设置监听,阻塞等待。
相关推荐
这个DBA有点耶11 分钟前
2026下半年数据库趋势:多模、云原生、AI融合
数据库·人工智能·云原生
逆境不可逃1 小时前
Hello-Agents 第二部分-第六章:框架开发实践
java·人工智能·分布式·学习·架构·rabbitmq
郭龙_Jack2 小时前
Java并发包(JUC)深度解析:从LockSupport到云原生演进
开发语言·云原生·java并发编程
小码哥0682 小时前
一套可复用的打车系统模板,微服务版网约车系统|类似滴滴的打车平台
微服务·云原生·架构·滴滴·打车
富士康质检员张全蛋2 小时前
Kafka架构 HW和LEO
分布式·kafka
云游牧者3 小时前
K8S控制器全解-从RS到DaemonSet实战完全指南
云原生·容器·kubernetes·控制器
步步为营DotNet4 小时前
深挖.NET 11:.NET Aspire 在云原生应用状态管理的创新与实践
云原生·.net·wpf
gQ85v10Db4 小时前
Redis分布式锁进阶第三十八篇
数据库·redis·分布式
豆沙沙包?4 小时前
SpringCloud01-03---简介/从单体到集群架构/从单体到分布式架构
分布式·微服务·架构·springcloud
Apache RocketMQ4 小时前
Apache RocketMQ 5.0 架构解析:如何基于云原生架构支撑多元化场景
云原生·架构·apache·rocketmq·java-rocketmq