基于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. 判断自己是不是序列化最小的一个节点。 如果是的话,上锁成功;如果不是的话,则上锁失败,为上一个节点设置监听,阻塞等待。
相关推荐
回家路上绕了弯11 小时前
接口响应时间优化指南:从秒级到毫秒级的全链路方案
分布式·后端
RestCloud11 小时前
OceanBase 分布式数据库的 ETL 实践:从抽取到实时分析
数据库·分布式·postgresql·oceanbase·etl·数据处理·数据同步
西***634713 小时前
从信号零损耗到智能协同:高清混合矩阵全链路技术拆解,分布式可视化系统十大趋势重塑行业
分布式·线性代数·矩阵
眠りたいです13 小时前
基于脚手架微服务的视频点播系统-脚手架开发部分-FFmpeg,Etcd-SDK的简单使用与二次封装
c++·微服务·云原生·架构·ffmpeg·etcd
菜鸡儿齐1 天前
kafka简介
分布式·kafka
周杰伦_Jay1 天前
【实战|旅游知识问答RAG系统全链路解析】从配置到落地(附真实日志数据)
大数据·人工智能·分布式·机器学习·架构·旅游·1024程序员节
兜兜风d'1 天前
RabbitMQ事务机制详解
数据库·spring boot·分布式·rabbitmq·ruby·java-rabbitmq
ifeng09181 天前
HarmonyOS分布式任务调度——跨设备智能任务分配与迁移
分布式·华为·harmonyos
9ilk1 天前
【仿RabbitMQ的发布订阅式消息队列】--- 模块设计与划分
c++·笔记·分布式·后端·中间件·rabbitmq
AKAMAI1 天前
以 Akamai Inference Cloud 实现无处不在的人工智能
人工智能·云原生·云计算