Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1959506
  • 博文数量: 1000
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 7921
  • 用 户 组: 普通用户
  • 注册时间: 2013-08-20 09:23
个人简介

storage R&D guy.

文章分类

全部博文(1000)

文章存档

2019年(5)

2017年(47)

2016年(38)

2015年(539)

2014年(193)

2013年(178)

分类: 云计算

2015-07-27 17:58:42

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



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