基于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. 判断自己是不是序列化最小的一个节点。如果是的话,上锁成功;如果不是的话,则上锁失败,为上一个节点设置监听,阻塞等待。

相关推荐

  1. ZooKeeper分布式

    2024-05-26 01:32:16       15 阅读
  2. ZooKeeper 分布式实现方法

    2024-05-26 01:32:16       20 阅读
  3. zookeeper分布式

    2024-05-26 01:32:16       20 阅读
  4. ZooKeeper分布式

    2024-05-26 01:32:16       29 阅读
  5. Zookeeper实现分布式

    2024-05-26 01:32:16       24 阅读
  6. Zookeeper实现分布式(Zk分布式

    2024-05-26 01:32:16       16 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-05-26 01:32:16       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-26 01:32:16       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-26 01:32:16       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-26 01:32:16       20 阅读

热门阅读

  1. 掌握C++回调:按值捕获、按引用捕获与弱引用

    2024-05-26 01:32:16       12 阅读
  2. 【数据结构与算法 | 基础篇】数组模拟栈

    2024-05-26 01:32:16       12 阅读
  3. 银发经济:老龄化社会中的机遇与挑战

    2024-05-26 01:32:16       10 阅读
  4. 基于Amazon Cognito的安全登录与资源访问

    2024-05-26 01:32:16       11 阅读
  5. ORACLE 6节点组成的ACFS文件系统异常的分析思路

    2024-05-26 01:32:16       11 阅读
  6. Nginx 从入门到精通-Nginx-Web服务器的瑞士军刀

    2024-05-26 01:32:16       12 阅读
  7. PostgreSQL入门教程

    2024-05-26 01:32:16       9 阅读
  8. 系统分析师-案例分析-数据库

    2024-05-26 01:32:16       15 阅读
  9. 巧用count与count()

    2024-05-26 01:32:16       10 阅读
  10. React hooks - forwardRef+useImperativeHandle

    2024-05-26 01:32:16       11 阅读
  11. 安卓adb 抓取模拟器日志

    2024-05-26 01:32:16       11 阅读