Zookeeper实现分布式锁的核心原理

INFO

作者: 编程界的小学生

日期: 2021/09/20

修订: 初版,未修订。2021/09/20

版权: 内部资料,切勿泄漏,违者必究。

一、回顾

之前我们花了十几个篇幅来讲解分布式锁是什么以及Redis实现分布式锁的各种方式的底层源码剖析。实现分布式锁的方式不仅有Redis,还有Zookeeper,那Zookeeper如何实现分布式锁呢?相当于Redis来讲,Zookeeper实现分布式锁太简单了!也相对更可靠。

二、实现思路

Zookeeper实现分布式锁的核心原理是什么?

是临时节点,更好的一点说法是临时顺序节点。

什么是临时节点?zookeeper为我们提供的一个几点类型,此节点类型的最大特性是:没有过期时间的概念,当客户端宕机后,临时节点会随之消亡。 想想Redis作为分布式锁的时候,防止宕机死锁,需要添加过期时间,防止提前过期还要开启watchDog定时续期。太繁琐,越繁琐越不可靠。那Zookeeper实现分布式锁就太简单了。直接利用临时节点。

当客户端抢锁后就给这个客户端分配一个临时节点,只要他没释放锁就一直持有这个临时节点,当他释放后或者服务意外宕机的话,临时节点都会被删除,这样其他客户端又能抢锁。 Zoo

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

【原】编程界的小学生

没有打赏我依然会坚持。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值