• ZooKeeper学习总结(2)——ZooKeeper开源Java客户端ZkClient使用


    zkclient是zookeeper的Java客户端。它让Zookeeper API 使用起来更简单;它非常方便订阅各种事件并自动重新绑定事件(会话建立、节点修改、节点删除、子节点变更等);它提供了session过期自动重连等机制。今天我们主要讲解的是如何使用zkclient的基础api。

    首先我们创建一个maven工程,将jar引进来,下面是maven的依赖:

    ZooKeeper的开源客户端ZkClient

    1、创建会话

    ZooKeeper的开源客户端ZkClient

    (1)zkServers 指的是zk的服务器列表,由英文状态逗号分开的host:port字符串组成,每一个都代表一台zk机器,例如192,168,11,160:2181,192,168,11,161:2181...

    (2)sessionTimeout 会话超时时间,单位为毫秒,默认为30000ms

    (3)connectionTimeout 连接创建的超市时间,单位为毫秒,此参数表明如果在这个时间段内还是无法和zk建立连接,那么就放弃连接直接抛出异常

    (4)connection IZKConnection 接口的实现类

    (5)zkSerializer 自定义的序列化器

    在使用zk的api创建连接的时候我们知道,创建连接的过程是一个异步过程,我们需要自己通过线程阻塞来监听链接是否创建成功,而在zkclient里,将异步方式转为了同步方式。这样会更加方便。

    IZKconnection接口。这个接口是对zk原生接口最直接的包装,也是和zk最直接的交互层,里面包含了增,删,改,查等接口。zkClient有两种实现方式分别是ZkConnection和InMemoryConnection ,而ZkConnection是常用的。

    ZkSerializer接口。这个接口是用来完成data数据序列化用的,默认情况下zkc使用Java自带的序列化方式对对象进行序列化。

    在zkclient的构造方法里我们没有找到对watcher的传入,那如何实现监听呢,zkclient使用listener来实现watcher注册

    ZooKeeper的开源客户端ZkClient

    2、创建节点

    ZooKeeper的开源客户端ZkClient

    (1)path 节点路径 (2)data 数据 (3)mode 节点类型 (4)cal 权限策略 (5)callback 异步回调函数 (6)context 上下文对象 (7)createParents 指定是否创建父节点。在这些参数里,和zk自带的api都差不多,其中data因为有了自定义的序列化工具,所以可以传入更为复杂的对象。

    ZooKeeper的开源客户端ZkClient

    ZooKeeper的开源客户端ZkClient

    3、删除节点

    刚才我们创建了一个永久的节点,下面我们来使用delete方法删除这个节点:

    ZooKeeper的开源客户端ZkClient

    ZooKeeper的开源客户端ZkClient

    但还有一个方法:deleteRecursive 这个方法可以帮助我们逐层遍历删除节点的工作。

    4、获取节点,注册监听

    ZooKeeper的开源客户端ZkClient

    这个方法没有注册watcher,所以我们现在先讲一个如何注册listener。下面这个listener接口可以完成节点的监听。

    ZooKeeper的开源客户端ZkClient

    问题是我们如何将这个监听器注册呢,我们可以使用subscribeChildChanges方法完成注册,下面我们来看一下demo

    ZooKeeper的开源客户端ZkClient

    经过测试,得出以下结论:

    (1)客户端可以对一个不存在的节点进行子节点变更的监听

    (2)一旦客户端对一个节点注册了子节点列表变更监听之后,那么该节点的字节列表发生变化的时候,服务端都会通知客户端,并将最新的子节点列表发送给客户端。

    (3)该节点本身的创建或删除会通知到客户端。

    (4)listener只需要注册一次会一直生效。

    5、获取与更新数据

    ZooKeeper的开源客户端ZkClient

    (1)returnNullIfPathNotExists 默认情况下 在调用这个方法的时候 如果指定的节点不存在会抛出异常,如果设置了这个参数 如果节点不存在就返回null 而不会抛出异常

    (2)stat 指定数据节点的节点状态信息 用户是在接口中传入一个旧的stat变量 该stat变量会在方法执行过程中被来自服务器响应的新的stat对象替换。

    来看一下DEMO案例

    ZooKeeper的开源客户端ZkClient

    ZooKeeper的开源客户端ZkClient


  • 相关阅读:
    UNIX/Linux打包,压缩 ,解压:
    Vertica删除历史分区数据
    在非归档模式下不能更改表空间为备份模式
    Oracle数据库文件路径变更
    impdp导入报错ORA-14460: only one COMPRESS or NOCOMPRESS clause may be specified
    IP,路由,交换基础培训记录
    Sybase 数据库新增用户,赋权
    struts2 接口如何接收客户端提交的json数据
    JavaWeb 发送get请求
    JavaWeb 发送post请求的2种方式(form、json)
  • 原文地址:https://www.cnblogs.com/zhanghaiyang/p/7212791.html
Copyright © 2020-2023  润新知