zookeeper实现分布式锁

分布式锁是控制分布式系统之间同步访问共享资源的一种方式。如果在不同主机间共享了一个或一组资源,访问这些资源的时候,为了保证一致性,就需要使用分布式锁。

为什么要使用分布式锁?

一般情况下,在实际的开发中会使用数据库固有的排他性来实现不同程度的互斥,但是目前大部分的业务的瓶颈却是在数据库上,如果再加上行锁,表锁,数据库的性能变得更低。

排他锁

什么是排他锁(Exclusive Locks,简称 X 锁)?

如果事务 T 对对象 O 加上了排他锁,那么整个加锁期间,只有 T 能对 O 进行读取和更新操作,知道 T 释放了排他锁。

定义排他锁

获取排他锁

在需要获取排他锁时,所有的客户端调用 create() 接口,在 /exclusive_lock 节点下创建临时节点 /exclusive_lock/lock。zookeeprer 保证只有一个客户端创建成功,创建成功的客户端获得锁,没有创建成功的客户端在 /exclusive_lock 注册一个子节点变更的 Watch 监听。当监听到子节点变更后,重复上边流程。

释放排他锁

因为 /exclusive_lock/lock 是临时节点,那么两种情况下会释放锁。

  • 执行完逻辑后,客户端主动将 /exclusive_lock/lock 删除。
  • 获得锁的客户端宕机。

整体流程

上篇Java 序列化与反序列化
下篇Java 中的 单例