Skip to content

Latest commit

 

History

History
6 lines (3 loc) · 1.3 KB

实现一个原语:利用zookeeper实现锁.md

File metadata and controls

6 lines (3 loc) · 1.3 KB

使用Zookeeper的一个简单例子就是通过锁来实现临界区。目前有多种锁(如读写锁,全局锁),使用Zookeeper来实现锁也有多种方式。这里我们讨论一个简单的秘方来说明应用如何使用Zookeeper,不考虑其它锁的变体。

假设我们现在有一个应用,其中有n个进程尝试获取一个锁。回想到Zookeeper是不直接暴露原语,所以我们需要使用Zookeeper的接口来操作一个znode以此来实现一个锁。为了得到锁,每个进程p都尝试创建一个znode节点,例如/lock。如果p成功地创建了节点,那么它就获得了锁,也就能执行它的临界区的代码了。一个潜在的问题是进程p可能会奔溃,永远不会释放锁。这种情况下,没有其他的进程能够再次获取锁,系统可能会死锁。为了避免这种情况,当我们创建它的时候必须让/lock节点是临时节点。

只要节点存在,其他想创建/lock节点进程都会失败。所以,它们监视/lock节点的变化,一旦它们检测到了/lock节点被删除了就会再次尝试获取锁。当收到/lock节点被删除的通知时,如果进程p'还对获取锁感兴趣的话,它会重复创建/lock节点的步骤。如果另外一个进程已经创建了节点,那么继续监视它。