Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1297718
  • 博文数量: 127
  • 博客积分: 2286
  • 博客等级: 大尉
  • 技术积分: 1943
  • 用 户 组: 普通用户
  • 注册时间: 2010-06-10 10:37
文章分类

全部博文(127)

文章存档

2018年(1)

2015年(2)

2014年(1)

2013年(30)

2012年(88)

2011年(5)

分类: 云计算

2012-05-30 16:21:21

许多博文多说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个版本。根据自己的需要来选择不同的函数,不同的版本



阅读(8062) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~