Zookeeper分布式锁服务

wera00 2016-04-29

zookeeper其实是集群中每个节点都维护着一棵相同的树, 树的结构跟linux的目录结构的概念差不多, 以/为跟节点, 下边可以扩展任意的节点和叶子节点, 每个节点都可以写入数据. 基于zookeeper的分布式锁的实现, 其实是得益于zookeeper同步文件的强大性, 我们相信每时每刻我们访问zookeeper的树时, 相同节点返回的数据都是一致的. 这要靠zookeeper内部的一些算法来实现. 特别是leader的选举算法, 这里就不说了, 感兴趣的话可以去搜索一下看看.

    我们知道了zookeeper集群的每个节点的数据都是一致的, 那么我们可以通过这些节点来作为锁的标志.

    首先给锁设置一下API, 至少要包含, lock(锁住), unlock(解锁), isLocked(是否锁住)三个方法

   然后我们可以创建一个工厂(LockFactory), 用来专门生产锁.

  1. 根据指定的路径,查找Zookeerper集群下,这个节点是否存在(有则存在锁)

  2. 如果存在, 根据查询者的一些特征数据(如ip地址/hostname), 当前的锁是不是查询者的

  3. 如果不是查询者的锁, 则返回null, 说明创建锁失败

  4.  如果是查询者的锁, 则把这个锁返回给查询者

  5. 如果这个节点不存在, 说明当前没有锁, 那么创建一个临时节点, 并将查询者的特征信息写入这个节点的数据中, 然后返回这个锁.

根据以上5部, 一个分布式的锁就可以创建了.

创建的锁有三种状态:

1. 创建失败(null), 说明该锁被其他查询者使用了;

2. 创建成功, 但当前没有锁住(unlocked), 可以使用;

3. 创建成功, 但当前已经锁住(locked)了, 不能继续加锁;

代码实现在这里

http://www.oschina.net/code/snippet_1403215_55368

相关推荐