ZooKeeper监听机制
前言:Zookeeper的监听机制很多人都踩过坑,感觉实现了watcher 接口,后面节点的变化都会一一推送过来,然而并非如此。
Watch机制官方声明:一个Watch事件是一个一次性的触发器,当被设置了Watch的数据发生了改变的时候,则服务器将这个改变发送给设置了Watch的客户端,以便通知它们。
Zookeeper机制的特点:
1.一次性触发 数据发生改变时,一个watcher event会被发送到client,但是client只会收到一次这样的信息。
2.watcher event异步发送 watcher 的通知事件从server发送到client是异步的,这就存在一个问题,不同的客户端和服务器之间通过socket进行通信,由于网络延迟或其他因素导致客户端在不通的时刻监听到事件,由于Zookeeper本身提供了ordering guarantee,即客户端监听事件后,才会感知它所监视znode发生了变化。
3.数据监视 Zookeeper有数据监视和子数据监视 getdata() and exists() 设置数据监视,getchildren()设置了子节点监视
4.注册watcher getData、exists、getChildren
5. 触发watcher create、delete、setData
|
watcher里面的相关事件 |
||
|
event For "/path" |
event For "/path/child" |
|
|
create("/path") |
EventType.NodeCreated |
NA |
|
delete("/path") |
EventType.NodeDeleted |
NA |
|
setData("/path") |
EventType.NodeDataChanged |
NA |
|
create("/path/child") |
EventType.NodeChildrenChanged |
EventType.NodeCreated |
|
delete("/path/child") |
EventType.NodeChildrenChanged |
EventType.NodeDeleted |
|
setData("/path/child") |
NA |
EventType.NodeDataChanged |
|
各种操作触发的watcher事件 |
||||||||
|
"/path" |
"/path/child" |
|||||||
|
exists |
getData |
getChildren |
exists |
getData |
getChildren |
|||
|
create("/path") |
√ |
√ |
||||||
|
delete("/path") |
√ |
√ |
√ |
|||||
|
setData("/path") |
√ |
√ |
||||||
|
create("/path/child") |
√ |
√ |
√ |
|||||
|
delete("/path/child") |
√ |
√ |
√ |
√ |
||||
|
setData("/path/child") |
√ |
√ |
||||||
|
操作与watcher关系 |
|||||||
|
"/path" |
"/path/child" |
||||||
|
exists |
getData |
getChildren |
exists |
getData |
getChildren |
||
|
create("/path") |
√ |
√ |
|||||
|
delete("/path") |
√ |
√ |
√ |
||||
|
setData("/path") |
√ |
√ |
|||||
|
create("/path/child") |
√ |
√ |
√ |
||||
|
delete("/path/child") |
√ |
√ |
√ |
√ |
|||
|
setData("/path/child") |
√ |
√ |
|||||
各种watch测试
/**
* watch test
*
*/
public class App implements Watcher { private static CountDownLatch connectedSemaphore = new CountDownLatch(1);
public static Stat stat = new Stat();
ZooKeeper zooKeeper; public static void main(String[] args) throws IOException, InterruptedException, KeeperException {
String p = "/testaa";
ZooKeeper zooKeeper = new ZooKeeper("192.168.1.10:2181", 5000, new App());
connectedSemaphore.await();
//exists register watch
zooKeeper.exists(p, true);
String path = zooKeeper.create(p, "456".getBytes(), Ids.OPEN_ACL_UNSAFE,
CreateMode.PERSISTENT);
//get register watch
zooKeeper.getData(path, true, stat);
zooKeeper.setData(path, "hhhh".getBytes(), -1);
zooKeeper.exists(path, true);
//exists register watch
zooKeeper.delete(path, -1); } public void process(WatchedEvent event) {
if (KeeperState.SyncConnected == event.getState()) {
if (EventType.None == event.getType() && null == event.getPath()) {
connectedSemaphore.countDown();
System.out.println("Zookeeper session established");
} else if (EventType.NodeCreated == event.getType()) {
System.out.println("success create znode"); } else if (EventType.NodeDataChanged == event.getType()) {
System.out.println("success change znode: " + event.getPath()); } else if (EventType.NodeDeleted == event.getType()) {
System.out.println("success delete znode"); } else if (EventType.NodeChildrenChanged == event.getType()) {
System.out.println("NodeChildrenChanged"); } }
}
}
ZooKeeper监听机制的更多相关文章
- Zookeeper数据类型、节点类型、角色、watcher监听机制
1.Zookeeper数据类型:层次化目录结构+少量数据 Zookeeper包含层次化的目录结构,每个Znode都有唯一的路径标识,Znode可以包含数据和子节点. 其中Znode数据可以有多个版本, ...
- 4.JAVA之GUI编程事件监听机制
事件监听机制的特点: 1.事件源 2.事件 3.监听器 4.事件处理 事件源:就是awt包或者swing包中的那些图形用户界面组件.(如:按钮) 事件:每一个事件源都有自己特点有的对应事件和共性事件. ...
- .NET事件监听机制的局限与扩展
.NET中把“事件”看作一个基本的编程概念,并提供了非常优美的语法支持,对比如下C#和Java代码可以看出两种语言设计思想之间的差异. // C#someButton.Click += OnSomeB ...
- java 24 - 2 GUI之监听机制和适配器改进窗口关闭
我们创建了窗体后,就要对窗体进行操作,比如关闭窗口.而这时候就要建立监听机制: 事件监听机制: A:事件源 事件发生的地方 B:事件 就是要发生的事情 C:事件处理 就是针对发生的事情做出的处理方案 ...
- 关于JAVA中事件分发和监听机制实现的代码实例-绝对原创实用
http://blog.csdn.net/5iasp/article/details/37054171 文章标题:关于JAVA中事件分发和监听机制实现的代码实例 文章地址: http://blog.c ...
- 关于事件监听机制的总结(Listener和Adapter)
记得以前看过事件监听机制背后也是有一种设计模式的.(设计模式的名字记不清了,只记得背后实现的数据结构是数组.) 附上事件监听机制的分析图: 一个事件源可以承载多个事件(只要这个事件源支持这个事件就可以 ...
- GUI编程笔记(java)05:GUI事件监听机制原理和举例说明
1.事件监听机制: A:事件源 事件发生的地方 B:事件 就是要发生的事情 C:事件处理 就是针对发生的事情做 ...
- JAVA事件监听机制学习
//事件监听机制 import java.awt.*; import java.awt.event.*; public class TestEvent { public static void mai ...
- Java中的事件监听机制
鼠标事件监听机制的三个方面: 1.事件源对象: 事件源对象就是能够产生动作的对象.在Java语言中所有的容器组件和元素组件都是事件监听中的事件源对象.Java中根据事件的动作来区分不同的事件源对象,动 ...
随机推荐
- BrowserSync的安装和使用
BrowserSync真是前端必备神器,浏览器同步工具.简单来说就是当你保存文件的同时浏览器自动刷新网页,省去了手动的环节,大大的节省了开发时间,这个工具是基于nodejs的,可以通过npm安装,不在 ...
- ksum问题
2sum: Given an array of integers, return indices of the two numbers such that they add up to a speci ...
- webdriver介绍&与Selenium RC的比较
什么是webdriver? webdriver是一个web自动化测试框架,不同于selenium IDE只能运行在firefox上,webdriver能够在不同的浏览器上执行你的web测试用例.其支持 ...
- [Python]peewee使用经验
peewee 使用经验 本文使用案例是基于 python2.7 实现 以下内容均为个人使用 peewee 的经验和遇到的坑,不会涉及过多的基本操作.所以,没有使用过 peewee,可以先阅读文档 正确 ...
- Use “error_messages” in Rails 3.2? (raises “undefined method” error)
I am getting the following error in my Rails 3.2 functional tests: ActionView::Template::Error: unde ...
- Redis分布式锁
Redis分布式锁 分布式锁是许多环境中非常有用的原语,其中不同的进程必须以相互排斥的方式与共享资源一起运行. 有许多图书馆和博客文章描述了如何使用Redis实现DLM(分布式锁管理器),但是每个库都 ...
- Android -- Annotation(注解)原理详解及常见框架应用
1,我们在上一篇讲到了EventBus源码及3.0版本的简单使用,知道了我们3.0版本是使用注解方式标记事件响应方法的,这里我们就有一个疑问了,为什么在一个方法加上类似于"@Subscrib ...
- 快速排序算法回顾 --冒泡排序Bubble Sort和快速排序Quick Sort(Python实现)
冒泡排序的过程是首先将第一个记录的关键字和第二个记录的关键字进行比较,若为逆序,则将两个记录交换,然后比较第二个记录和第三个记录的关键字.以此类推,直至第n-1个记录和第n个记录的关键字进行过比较为止 ...
- Eclipse实现图形化界面插件-vs4e
vs4e插件下载地址:http://visualswing4eclipse.googlecode.com/files/vs4e_0.9.12.I20090527-2200.zip 下载完成后,解压,然 ...
- 兼容IE8的input输入框的正确使用姿势
input是一个很常见的标签,大家使用的也很常见,但是我在具体的工作中发现要想完美的使用这个标签还是任重而道远,下面是我碰到的几个问题. 1.我们在使用这个标签的时候会习惯的加上placeholder ...