storage R&D guy.
全部博文(1000)
分类: 云计算
2015-07-27 17:58:42
原文地址:zookeeper事件的触发条件和再触发 作者:kerlion
许多博文多说zookeeper是one time trigger,这个说法不够准确,有误导之嫌:
Zookeeper的watch实际上要处理两类事件
1. 连接状态事件(type=None, path=null)
这类事件不需要注册,也不需要我们连续触发,我们只要处理就行了。
2. 节点事件
节点的建立,删除,数据的修改。它是one time trigger,我们需要不停的注册触发,还可能发生事件丢失的情况。
上面2类事件都在Watch中处理,也就是重载的process(Event event)
节点事件的触发,通过函数exists,getData或getChildren来实现
这类函数,有双重作用:
函数的本身的功能又可以用过异步的回调函数来实现,重载processResult()过程中处理函数本身的的功能。
函数还可以指定自己的watch,所以每个函数都有4个版本。根据自己的需要来选择不同的函数,不同的版本