原生的zookeeper的监听API所实现的方法存在一些缺点,对于开发者来说后续的开发会考虑的细节比较多。

Curator所实现的方法希望摒弃原声API 的不足,是开发看起来更加的简单,一些重连等操作对开发者变成了透明操作,而不需要去考虑。

1. Curator的监听API

Curator的监听实现是对zookeeper原生监听方法的高级封装,主要体现在两点:监听重复注册,事件发生信息。而且监听事件返回详细的信息,如变动的节点信息,节点的value等。

Curator 提供了3个接口,包含在org.apache.curator.framework.recipes.cache下(点击超链接可查看对应的javadoc)

如图所示:

1) NodeCache: 对一个节点进行监听,监听事件包括指定的路径节点的增、删、改的操作。

2) PathChildrenCache: 对指定的路径节点的一级子目录进行监听,不对该节点的操作进行监听,对其子目录的节点进行增、删、改的操作监听

3) TreeCache:  可以将指定的路径节点作为根节点(祖先节点),对其所有的子节点操作进行监听,呈现树形目录的监听,可以设置监听深度,最大监听深度为2147483647(int类型的最大值)。

2. NodeCache

Node Cache - A utility that attempts to keep the data from a node locally cached. This class will watch the node, respond to update/create/delete events, pull down the data, etc. You can register a listener that will get notified when changes occur. (官网)

部分样例代码

NodeCache nodeCache = null;

nodeCache.start(true);
  // 如果为true则首次不会缓存节点内容到cache中,默认为false,设置为true首次不会触发监听事件

nodeCache.getListenable().addListener(new NodeCacheListener(){

            @Override
public void nodeChanged() throws Exception {
// 节点发生变化,回调方法
byte[] ret = nodeCache.getCurrentData().getData();
// getData()方法实现返回byte[]
System.out.println("数据发生变化: " + new String(ret));
} });

说明:

       /*
* 节点路径不存在,set不触发监听
* 节点路径不存在,创建事件触发监听(第一次创建时要触发)
* 节点路径存在,set触发监听(改操作触发)
* 节点路径存在,delete触发监听(删操作触发)
*
* 节点挂掉,未触发任何监听
* 节点重连,未触发任何监听
* 节点重连 ,恢复监听
* */

2. PathChildrenCache

Path Cache - A Path Cache is used to watch a ZNode. Whenever a child is added, updated or removed, the Path Cache will change its state to contain the current set of children, the children's data and the children's state. Path caches in the Curator Framework are provided by the PathChildrenCache class. Changes to the path are passed to registered PathChildrenCacheListener instances.(官网)

部分样例代码:

PathChildrenCache pathChildrenCache = null;

pathChildrenCache.start(PathChildrenCache.StartMode.BUILD_INITIAL_CACHE);
pathChildrenCache.getListenable().addListener(new PathChildrenCacheListener(){ @Override
public void childEvent(CuratorFramework client,
PathChildrenCacheEvent event) throws Exception {
//
switch(event.getType()) {
case CHILD_ADDED:
System.out.println("添加了儿子节点 " + event.getData());
break;
case CHILD_UPDATED:
System.out.println("儿子节点发生了更新 " + event.getData());
break;
case CHILD_REMOVED:
System.out.println("儿子节点移除 " + event.getData());
case CONNECTION_SUSPENDED: break;
// ZK挂掉
case CONNECTION_RECONNECTED: break;
// 重新启动ZK
case CONNECTION_LOST: break;
// ZK挂掉一段时间后
case INITIALIZED: break;
default: break;
}
} });

说明:

        /**
* 注册监听器,当前节点不存在,创建该节点:未抛出异常及错误日志
* 注册子节点触发type=[CHILD_ADDED]
* 更新触发type=[CHILD_UPDATED]
*
* zk挂掉type=CONNECTION_SUSPENDED,,一段时间后type=CONNECTION_LOST
* 重启zk:type=CONNECTION_RECONNECTED, data=null
* 更新子节点:type=CHILD_UPDATED, data=ChildData{path='/zktest111/tt1', stat=4294979983,4294979993,1501037475236,1501037733805,2,0,0,0,6,0,4294979983
,data=[55, 55, 55, 55, 55, 55]}

* 删除子节点type=CHILD_REMOVED
* 更新根节点:不触发
* 删除根节点:不触发 无异常
* 创建根节点:不触发
* 再创建及更新子节点不触发
*
* 重启时,与zk连接失败
*/

3. TreeCache

Tree Cache - A utility that attempts to keep all data from all children of a ZK path locally cached. This class will watch the ZK path, respond to update/create/delete events, pull down the data, etc. You can register a listener that will get notified when changes occur.(官网)

部分样例代码:

TreeCache treeCache = null;

treeCache.start();
// 没有开启模式作为入参的方法 treeCache.getListenable().addListener(new TreeCacheListener(){ @Override
public void childEvent(CuratorFramework client, TreeCacheEvent event)
throws Exception {
//
switch(event.getType()) {
case NODE_ADDED:
System.out.println("tree:发生节点添加" + event.getData().toString() ); break;
case NODE_UPDATED:
System.out.println("tree:发生节点更新"); break;
case NODE_REMOVED:
System.out.println("tree:发生节点删除"); break;
case CONNECTION_SUSPENDED:
break;
case CONNECTION_RECONNECTED:
break;
case CONNECTION_LOST:
break;
case INITIALIZED:
System.out.println("初始化的操作"); break;
default:
break;
}
} });

说明:

        /**
* TreeCache.nodeState == LIVE的时候,才能执行getCurrentChildren非空,默认为PENDING
* 初始化完成之后,监听节点操作时 TreeCache.nodeState == LIVE
*
* maxDepth值设置说明,比如当前监听节点/t1,目录最深为/t1/t2/t3/t4,则maxDepth=3,说明下面3级子目录全
* 监听,即监听到t4,如果为2,则监听到t3,对t3的子节点操作不再触发
* maxDepth最大值2147483647
*
* 初次开启监听器会把当前节点及所有子目录节点,触发[type=NODE_ADDED]事件添加所有节点(小等于maxDepth目录)
* 默认监听深度至最低层
* 初始化以[type=INITIALIZED]结束
*
* [type=NODE_UPDATED],set更新节点值操作,范围[当前节点,maxDepth目录节点](闭区间)
*
*
* [type=NODE_ADDED] 增加节点 范围[当前节点,maxDepth目录节点](左闭右闭区间)
*
* [type=NODE_REMOVED] 删除节点, 范围[当前节点, maxDepth目录节点](闭区间),删除当前节点无异常
*
* 事件信息
* TreeCacheEvent{type=NODE_ADDED, data=ChildData{path='/zktest1', stat=4294979373,4294979373,1499850881635,1499850881635,0,0,0,0,2,0,4294979373
, data=[116, 49]}}
*
*/

8、Curator的监听机制的更多相关文章

  1. Curator的监听机制

    原生的zookeeper的监听API所实现的方法存在一些缺点,对于开发者来说后续的开发会考虑的细节比较多. Curator所实现的方法希望摒弃原声API 的不足,是开发看起来更加的简单,一些重连等操作 ...

  2. Zookeeper Curator 事件监听 - 秒懂

    目录 写在前面 1.1. Curator 事件监听 1.1.1. Watcher 标准的事件处理器 1.1.2. NodeCache 节点缓存的监听 1.1.3. PathChildrenCache ...

  3. 4.JAVA之GUI编程事件监听机制

    事件监听机制的特点: 1.事件源 2.事件 3.监听器 4.事件处理 事件源:就是awt包或者swing包中的那些图形用户界面组件.(如:按钮) 事件:每一个事件源都有自己特点有的对应事件和共性事件. ...

  4. .NET事件监听机制的局限与扩展

    .NET中把“事件”看作一个基本的编程概念,并提供了非常优美的语法支持,对比如下C#和Java代码可以看出两种语言设计思想之间的差异. // C#someButton.Click += OnSomeB ...

  5. java 24 - 2 GUI之监听机制和适配器改进窗口关闭

    我们创建了窗体后,就要对窗体进行操作,比如关闭窗口.而这时候就要建立监听机制: 事件监听机制: A:事件源 事件发生的地方 B:事件 就是要发生的事情 C:事件处理 就是针对发生的事情做出的处理方案 ...

  6. 关于JAVA中事件分发和监听机制实现的代码实例-绝对原创实用

    http://blog.csdn.net/5iasp/article/details/37054171 文章标题:关于JAVA中事件分发和监听机制实现的代码实例 文章地址: http://blog.c ...

  7. 关于事件监听机制的总结(Listener和Adapter)

    记得以前看过事件监听机制背后也是有一种设计模式的.(设计模式的名字记不清了,只记得背后实现的数据结构是数组.) 附上事件监听机制的分析图: 一个事件源可以承载多个事件(只要这个事件源支持这个事件就可以 ...

  8. GUI编程笔记(java)05:GUI事件监听机制原理和举例说明

    1.事件监听机制:       A:事件源          事件发生的地方       B:事件             就是要发生的事情       C:事件处理       就是针对发生的事情做 ...

  9. JAVA事件监听机制学习

    //事件监听机制 import java.awt.*; import java.awt.event.*; public class TestEvent { public static void mai ...

随机推荐

  1. tensorflow中命名空间、变量命名的问题

    1.简介 对比分析tf.Variable / tf.get_variable | tf.name_scope / tf.variable_scope的异同 2.说明 tf.Variable创建变量:t ...

  2. Centos 7 搭建DNS笔记

    bindind的程序包 bind-libs:被bind和bind-utils包中的程序共同用到的库文件: bind-utils:bind客户端程序集:提供了,dig , host, nslookup等 ...

  3. 1、安装Angular-CLI脚手架工具

    依赖环境的安装 1.安装node.js(版本在6以上) 查看版本号:node -v 2.安装npm(npm会随着node的安装一起被安装) 3.安装Python(我安装的是2.7.14),要安装环境变 ...

  4. Java 代理

    代理做一个简单的抽象: 代理模式包含如下角色: Subject:抽象主题角色.可以是接口,也可以是抽象类. RealSubject:真实主题角色.业务逻辑的具体执行者. ProxySubject:代理 ...

  5. react源码探索

    react核心部分为 虚拟dom对象 虚拟dom差异化算法 单向数据流渲染 组件生命周期 事件处理 1) 虚拟dom对象: reactDOM.render(args,element); 这个方法第一个 ...

  6. 说一说本人对linux系统学习的方法和经验

    摘要: 相信大伙都听说过linux系统,然而对于这个系统,总使让新手感觉茫然,诺达的系统.下面是一段百度中的介绍: 相信大伙都听说过linux系统,然而对于这个系统,总使让新手感觉茫然,诺达的系统.下 ...

  7. ssh连接虚拟机centos

    ssh连接虚拟机centos 虚拟机下CentOS7开启SSH连接 注意:安装虚拟机的时候,网络一定选择桥接模式.

  8. 福大软工 · 第十一次作业 - Alpha 事后诸葛亮(团队)

    福大软工·第十一次作业-Alpha事后诸葛亮 组长博客链接 本次作业博客链接 项目Postmortem 模板 设想和目标 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描 ...

  9. OC学习笔记

    备注:这里只是个人的观点,有的地方也是copy,多多指教,个人笔记,有侵犯你们版权的地方还望海涵!!! ARC单例模式的实现 使用alloc方法初始化一个类的实例的时候,默认是调用了 allocWit ...

  10. LeetCode 60 第K个排列

    题目: 给出集合 [1,2,3,…,n],其所有元素共有 n! 种排列. 按大小顺序列出所有排列情况,并一一标记,当 n = 3 时, 所有排列如下: "123" "13 ...