wera00 2016-04-29
zookeeper其实是集群中每个节点都维护着一棵相同的树, 树的结构跟linux的目录结构的概念差不多, 以/为跟节点, 下边可以扩展任意的节点和叶子节点, 每个节点都可以写入数据. 基于zookeeper的分布式锁的实现, 其实是得益于zookeeper同步文件的强大性, 我们相信每时每刻我们访问zookeeper的树时, 相同节点返回的数据都是一致的. 这要靠zookeeper内部的一些算法来实现. 特别是leader的选举算法, 这里就不说了, 感兴趣的话可以去搜索一下看看.
我们知道了zookeeper集群的每个节点的数据都是一致的, 那么我们可以通过这些节点来作为锁的标志.
首先给锁设置一下API, 至少要包含, lock(锁住), unlock(解锁), isLocked(是否锁住)三个方法
然后我们可以创建一个工厂(LockFactory), 用来专门生产锁.
根据指定的路径,查找Zookeerper集群下,这个节点是否存在(有则存在锁)
如果存在, 根据查询者的一些特征数据(如ip地址/hostname), 当前的锁是不是查询者的
如果不是查询者的锁, 则返回null, 说明创建锁失败
如果是查询者的锁, 则把这个锁返回给查询者
如果这个节点不存在, 说明当前没有锁, 那么创建一个临时节点, 并将查询者的特征信息写入这个节点的数据中, 然后返回这个锁.
根据以上5部, 一个分布式的锁就可以创建了.
创建的锁有三种状态:
1. 创建失败(null), 说明该锁被其他查询者使用了;
2. 创建成功, 但当前没有锁住(unlocked), 可以使用;
3. 创建成功, 但当前已经锁住(locked)了, 不能继续加锁;
代码实现在这里
http://www.oschina.net/code/snippet_1403215_55368