本文为原创文章,转载请注明出处,谢谢

ZkClient使用

1、jar包引入,演示版本为0.8,非maven项目,可以下载jar包导入到项目中

<dependency>
<groupId>com.101tec</groupId>
<artifactId>zkclient</artifactId>
<version>0.8</version>
</dependency>

2、创建Zookeeper连接

 示例:ZkClient zc = new ZkClient("192.168.117.128:2181",10000,10000,new SerializableSerializer());

 API:ZkClient(java.lang.String zkServers, int sessionTimeout, int connectionTimeout, org.I0Itec.zkclient.serialize.ZkSerializer zkSerializer)

  • zkServers:Zookeeper服务器地址
  • sessionTimeout:session超时时间
  • connectionTimeout:连接超时时间
  • zkSerializer:序列化器,ZkClient提供2种
    • SerializableSerializer:对象序列化,可转换对象
    • BytesPushThroughSerializer:字节数组序列化

3、创建节点

示例:

 @Test
public void createNode() {
createSession();
User user = new User();
user.setId(1l);
user.setName("scot");
String path = zc.create("/zkClient_01/02",user, CreateMode.PERSISTENT);
System.out.println("path :" + path);
}

API:

public java.lang.String create(java.lang.String path, java.lang.Object data, org.apache.zookeeper.CreateMode mode) public java.lang.String create(java.lang.String path, java.lang.Object data, java.util.List<org.apache.zookeeper.data.ACL> acl, org.apache.zookeeper.CreateMode mode) 

示例用的为第一种,没有设置访问权限列表(List<org.apache.zookeeper.data.ACL> acl)

4、节点是否存在

  boolean exists(java.lang.String path);

5、获取节点信息

示例:

 @Test
public void getNode() {
createSession();
User user = zc.readData("/zkClient_01");
System.out.println(user.getName()); Stat stat = new Stat();
User user1 = zc.readData("/zkClient_01",stat);
System.out.println(user.getName());
System.out.println(stat);
}

API:

   public <T> T readData(java.lang.String path)public <T> T readData(java.lang.String path, boolean returnNullIfPathNotExists)public <T> T readData(java.lang.String path, org.apache.zookeeper.data.Stat stat)
  • path:节点路径。
  • returnnullIfPathNotExists:同字面意思,节点不存在返回null
  • stat:节点详细信息。传递stat对象到readData方法,方法内部会填充stat数据

6、获取子节点

示例:

@Test
public void getChild() {
createSession();
String path = "/node_scot";
boolean b = this.exists(path);
if(b) {
List<String> children =zc.getChildren(path);
System.out.println(children.size());
}else {
System.out.println("do not have this node");
}
}

API:

   public java.util.List<java.lang.String> getChildren(java.lang.String path) 

7、删除节点

示例:

 @Test
public void del() {
createSession();
String path = "/zkClient_01/01";
if(this.exists(path)) {
//zc.delete(path);//删除当前节点,有子节点无法删除
zc.deleteRecursive(path);//删除非子节点
}
}

API:

public boolean delete(java.lang.String path)

public boolean delete(java.lang.String path, int version) 

public boolean deleteRecursive(java.lang.String path) 
  • version:节点的版本。如果版本不符无法删除

8、更新节点信息

示例:

@Test
public void writeNode() {
createSession();
User user = new User();
user.setId(11l);
user.setName("sksujer002");
zc.writeData("/zkClient_01",user);
}

9、监控子节点改变(当前节点不存在也可以设置监控)

示例:

    @Test
public void subscribeChildChange() throws InterruptedException {
createSession();
zc.subscribeChildChanges("/zkClient_01",new MyZkChildListener());
Thread.sleep(Integer.MAX_VALUE);
} static class MyZkChildListener implements IZkChildListener { @Override
public void handleChildChange(String s, List<String> strings) throws Exception {
System.out.println("s:"+s);
System.out.println("Strings:" + strings);
}
}

API:

public java.util.List<java.lang.String> subscribeChildChanges(java.lang.String path, org.I0Itec.zkclient.IZkChildListener listener)

public interface IZkChildListener {
  void handleChildChange(java.lang.String parentPath, java.util.List<java.lang.String> currentChilds) throws java.lang.Exception;
}
  • subscribeChildChanges:注册子节点改变监控
    • path:路径
    • IZkChildListener listener:子节点监控接口
  • IZkChildListener - handChildChange:子节点列表发生改变触发此方法
    • parentPath:监控节点路径
    • currentChilds:子节点列表

10、监控节点数据

示例:

 @Test
public void subscribeDataChange () throws InterruptedException {
createSession();
zc.subscribeDataChanges("/zkClient_01",new MyZkDataListener());
Thread.sleep(Integer.MAX_VALUE);
} static class MyZkDataListener implements IZkDataListener { @Override
public void handleDataChange(String s, Object o) throws Exception {
System.out.println("节点信息改变");
System.out.println("s:"+s);
System.out.println("o:"+o);
} @Override
public void handleDataDeleted(String s) throws Exception {
System.out.println("节点被删除:"+s);
}
}

API:

 public void subscribeDataChanges(java.lang.String path, org.I0Itec.zkclient.IZkDataListener listener)

public interface IZkDataListener {
void handleDataChange(java.lang.String dataPath, java.lang.Object object) throws java.lang.Exception; void handleDataDeleted(java.lang.String dataPath) throws java.lang.Exception;
}
  • subscribeDataChanges:注册节点数据监控
    • IZkDataListener listener:数据改变监控接口
  • IZkDataListener - handleDataChange:节点数据改变触发此方法
    • dataPath:监控节点路径
    • object:节点的新数据
  • IZkDataListener - handleDataDeleted:节点被删除触发此方法
    • dataPath:监控节点路径

下一节:2.3Curator使用

(原) 2.2 ZkClient使用的更多相关文章

  1. 聊聊、Zookeeper 客户端 ZkClient

    [ZkClient]  ZkClient 是 GitHub 上一个开源的客户端,如果我们用 Maven 来管理工程,则引用如下. <dependency> <groupId>o ...

  2. 【原】谈谈对Objective-C中代理模式的误解

    [原]谈谈对Objective-C中代理模式的误解 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 这篇文章主要是对代理模式和委托模式进行了对比,个人认为Objective ...

  3. 【原】FMDB源码阅读(三)

    [原]FMDB源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 FMDB比较优秀的地方就在于对多线程的处理.所以这一篇主要是研究FMDB的多线程处理的实现.而 ...

  4. 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新

    [原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...

  5. 多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类)

    前言:刚学习了一段机器学习,最近需要重构一个java项目,又赶过来看java.大多是线程代码,没办法,那时候总觉得多线程是个很难的部分很少用到,所以一直没下决定去啃,那些年留下的坑,总是得自己跳进去填 ...

  6. 【原】FMDB源码阅读(二)

    [原]FMDB源码阅读(二) 本文转载请注明出处 -- polobymulberry-博客园 1. 前言 上一篇只是简单地过了一下FMDB一个简单例子的基本流程,并没有涉及到FMDB的所有方方面面,比 ...

  7. 【原】FMDB源码阅读(一)

    [原]FMDB源码阅读(一) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 说实话,之前的SDWebImage和AFNetworking这两个组件我还是使用过的,但是对于 ...

  8. 【原】AFNetworking源码阅读(六)

    [原]AFNetworking源码阅读(六) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 这一篇的想讲的,一个就是分析一下AFSecurityPolicy文件,看看AF ...

  9. 【原】AFNetworking源码阅读(五)

    [原]AFNetworking源码阅读(五) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇中提及到了Multipart Request的构建方法- [AFHTTP ...

随机推荐

  1. 使用sklearn做单机特征工程

    目录 1 特征工程是什么?2 数据预处理 2.1 无量纲化 2.1.1 标准化 2.1.2 区间缩放法 2.1.3 标准化与归一化的区别 2.2 对定量特征二值化 2.3 对定性特征哑编码 2.4 缺 ...

  2. Ajax_03之接收数据

    1.使用XHR接收服务器返回的数据--text 服务器端:  header('Content-Type:text/plain');  echo 'xxx'; 客户端:  xhr.responseTex ...

  3. Angular使用$compile为从Ajax加载的HTML绑定ng-click事件

    这是一个Angular使用$compile为从Ajax加载的HTML绑定ng-click事件的实现方式,由于近期忙碌,就先放代码.代码如下: <table data-ng-table=" ...

  4. 看看国外的javascript题目,你能全部做对吗?

    叶小钗 的博客最近都在讨论面试题目 正好以前也看过一篇,就借花献佛拿出来分享一下 http://perfectionkills.com/javascript-quiz/ 附带了自己的理解,答案有争议的 ...

  5. 小白学习MVC5+EF6遇到的问题一

    这两天有空的时候会看看Miro大神的MVC5+EF6系列文章,推荐大家看看. 以前没有接触过,纯小白一个,今天在学习的过程中遇到了一个问题,习惯了WebForm,在运行页面之前都会右键设置为起始页,我 ...

  6. 万能Adapter以及ViewHolder性能优化

    //CommonAdapter import android.content.Context; import android.widget.BaseAdapter; import java.util. ...

  7. javascript运动系列第三篇——曲线运动

    × 目录 [1]圆周运动[2]三维圆周 [3]钟摆运动 [4]抛物线[5]流体运动 前面的话 上一篇介绍了变速运动,但只实现了直线运动.如果元素的left和top同时运动,并遵循不同的曲线公式,则会进 ...

  8. ASP.NET MVC Ajax.ActionLink 简单用法

    ASP.NET MVC 项目中,如何使用类似于 iframe 的效果呢?或者说 Ajax 局部刷新,比如下面操作: 我们想要的效果是,点击 About 链接,页面不刷新(地址栏不变),然后下面的内容进 ...

  9. 如何在Windows Server 2008 上添加RD (远程桌面)会话主机配置的远程桌面授权服务器

    在Windows Server系列的现存活跃产品中都默认的会开放两个随机附送的远程控制的授权,而一些特殊条件下我们需要启用多个远程终端连接,在购买了相应的授权之后,我们如何将配置好的服务器添加到远程桌 ...

  10. objective-c 语法快速过(4)

    oc 里的字符串 字符串的快速创建(最简单的方法) NSStirng *str = @“Hello”;//oc的字符串都是@“”形式的 oc的字符串也是类的对象,是NSString类的对象,创建没有那 ...