前言

  zkClient主要做了两件事情:

    一件是在session loss和session expire时自动创建新的ZooKeeper实例进行重连。

    另一件是将一次性watcher包装为持久watcher。后者的具体做法是简单的在watcher回调中,重新读取数据的同时再注册相同的watcher实例。

zkClient目前已经运用到了很多项目中,知名的有Dubbo、Kafka、Helix。

  zkClient jar包下载,或者直接添加maven依赖: http://mvnrepository.com/artifact/com.101tec/zkclient

正文

  直接上代码:

1.测试类  

package com.xbq.demo;
import java.io.IOException;
import org.I0Itec.zkclient.ZkClient;
import org.I0Itec.zkclient.IZkDataListener; /**
* @ClassName: ZkClientDemo
* @Description: TODO(zkClient 测试)
* @author xbq
* @date 2017-3-26 上午11:49:39
*/
public class ZkClientDemo { // 此demo使用的集群,所以有多个ip和端口
private static String CONNECT_SERVER = "192.168.99.138:2181,192.168.99.138:2182,192.168.99.138:2183";
private static int SESSION_TIMEOUT = 3000;
private static int CONNECTION_TIMEOUT = 3000;
private static ZkClient zkClient ; static {
zkClient = new ZkClient(CONNECT_SERVER, SESSION_TIMEOUT,CONNECTION_TIMEOUT,new MyZkSerializer());
} public static void main(String[] args) { add(zkClient);
// update(zkClient);
// delete(zkClient); // addDiGui(zkClient);
// deleteDiGui(zkClient); // subscribe(zkClient);
} /**
* @Title: add
* @Description: TODO(增加一个指定节点)
* @param @param zkClient 设定文件
* @return void 返回类型
* @throws
*/
public static void add(ZkClient zkClient){
// 如果不存在节点,就新建一个节点
if(!zkClient.exists("/config")){
zkClient.createPersistent("/config","javaCoder");
}
// 查询一下,看是否增加成功
String value = zkClient.readData("/config");
System.out.println("value===" + value);
} /**
* @Title: addSequential
* @Description: TODO(递归创建节点)
* @param @param zkClient 设定文件
* @return void 返回类型
* @throws
*/
public static void addDiGui(ZkClient zkClient){
// 递归创建节点
zkClient.createPersistent("/xbq/java/coder", true);
if(zkClient.exists("/xbq/java/coder")){
System.out.println("增加成功!");
}else {
System.out.println("增加失败!");
}
} /**
* @Title: delete
* @Description: TODO(删除指定节点)
* @param @param zkClient 设定文件
* @return void 返回类型
* @throws
*/
public static void delete(ZkClient zkClient){
// 存在节点才进行删除
if(zkClient.exists("/config")){
boolean flag = zkClient.delete("/config");
System.out.println("删除" + (flag == true ? "成功!" : "失败!"));
}
} /**
* @Title: deleteDiGui
* @Description: TODO(递归删除)
* @param @param zkClient 设定文件
* @return void 返回类型
* @throws
*/
public static void deleteDiGui(ZkClient zkClient){
// 存在节点才进行删除
if(zkClient.exists("/xbq")){
// 递归删除的时候 只传入 父节点就可以,如果传入 全部的节点,虽然返回的是true,但是依然是没有删除的,
// 因为zkClient将异常封装好了,进入catch的时候,会返回true,这是一个坑
boolean flag = zkClient.deleteRecursive("/xbq");
System.out.println("删除" + (flag == true ? "成功!" : "失败!"));
}
} /**
* @Title: update
* @Description: TODO(修改节点的值)
* @param @param zkClient 设定文件
* @return void 返回类型
* @throws
*/
public static void update(ZkClient zkClient){
if(zkClient.exists("/config")){
zkClient.writeData("/config", "testUpdate");
// 查询一下,看是否修改成功
String value = zkClient.readData("/config");
System.out.println("value===" + value);
}
} /**
* @Title: subscribe
* @Description: TODO(事件订阅, 可用于配置管理)
* 先订阅,再 操作增删改。(可多个 客户端订阅)
* @param @param zkClient 设定文件
* @return void 返回类型
* @throws
*/
public static void subscribe(ZkClient zkClient){
zkClient.subscribeDataChanges("/config/userName", new IZkDataListener() {
@Override
public void handleDataDeleted(String arg0) throws Exception {
System.out.println("触发了删除事件:" + arg0);
} @Override
public void handleDataChange(String arg0, Object arg1) throws Exception {
System.out.println("触发了改变事件:" + arg0 + "-->" + arg1);
}
}); try {
System.in.read();
} catch (IOException e) {
e.printStackTrace();
}
}
}

2.自定义序列化类

package com.xbq.demo;

import org.I0Itec.zkclient.exception.ZkMarshallingError;
import org.I0Itec.zkclient.serialize.ZkSerializer; import java.io.UnsupportedEncodingException; /**
* @ClassName: MyZkSerializer
* @Description: TODO(实现序列化接口,转为UTF-8编码)
* @author xbq
* @date 2017-3-26 上午11:56:22
*/
public class MyZkSerializer implements ZkSerializer{
@Override
public byte[] serialize(Object data) throws ZkMarshallingError {
try {
return String.valueOf(data).getBytes("UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return null;
} @Override
public Object deserialize(byte[] bytes) throws ZkMarshallingError {
try {
return new String(bytes, "UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return null;
}
}

源码下载

  http://git.oschina.net/xbq8023/Zookeeper-Demo

ZooKeeper(四)-- 第三方客户端 ZkClient的使用的更多相关文章

  1. ZooKeeper:第三方客户端 ZKClient

    ZKClient ZKClient的设计 ZKClient组件说明 重要的处理流程说明 启动ZKClient 为节点注册Watcher ZooKeeper的变更操作 客户端处理变更 序列化处理 ZKC ...

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

    zkclient是zookeeper的Java客户端.它让Zookeeper API 使用起来更简单:它非常方便订阅各种事件并自动重新绑定事件(会话建立.节点修改.节点删除.子节点变更等):它提供了s ...

  3. [转载] ZooKeeper的Java客户端API

    转载自 http://www.cnblogs.com/ggjucheng/p/3370359.html http://zookeeper.apache.org/doc/trunk/javaExampl ...

  4. 【分布式】Zookeeper使用--开源客户端

    一.前言 上一篇博客已经介绍了如何使用Zookeeper提供的原生态Java API进行操作,本篇博文主要讲解如何通过开源客户端来进行操作. 二.ZkClient ZkClient是在Zookeepe ...

  5. 系列四TortoiseSvn客户端软件

    原文:系列四TortoiseSvn客户端软件 TortoiseSvn介绍 TortoiseSvn 是 Subversion 版本控制系统的一个免费开源客户端,可以超越时间的管理文件和目录.文件保存在中 ...

  6. zookeeper的WEB客户端zkui使用

    转载自:http://blog.csdn.net/csolo/article/details/53694665 前面几篇实践说明了zookeeper如何配置和部署,如何开发,因为大多是后台操作,对于维 ...

  7. zookeeper 四字命令

    zookeeper四字命令   ZooKeeper3.4.6支持某些特定的四字命令字母与其的交互.它们大多是查询命令,用来获取 ZooKeeper 服务的当前状态及相关信息.用户在客户端可以通过 te ...

  8. 02.ZooKeeper的Java客户端使用

    1.ZooKeeper常用客户端比较 1.ZooKeeper常用客户端     zookeeper的常用客户端有3种,分别是:zookeeper原生的.Apache Curator.开源的zkclie ...

  9. 六:ZooKeeper的java客户端api的使用

    一:客户端链接测试 package com.yeepay.sxf.createConnection; import java.io.IOException; import org.apache.zoo ...

随机推荐

  1. 由sqlite在手机上的存储位置,引发的onCreate在哪里执行的小结

    我们都知道,android为了操作数据库,一般是继承SQLiteOpenHelper类,并实现他的三个函数. 如下所示: package jz.his.db; import android.conte ...

  2. JavaScript高级 面向对象(5)--内存逻辑图画法

    说明(2017.3.30): 1. 使用软件diagram designer,DiagramDesignerSetup1.28.zip,很小只有1M多,我用的自带画图软件.教学视频是“JavaScri ...

  3. redis、mysql、和php原生array数组效率对比

    最近要做一个屏蔽词的功能,屏蔽词是保存在配置文件里,最开始是用php数组存储,然后查找. 后来随着屏蔽词的增多,速度明显的变慢了,于是考虑到用redis或mysql做. 于是写了一个测试,测试结果如下 ...

  4. C语言 · 十六进制转八进制

    基础练习 十六进制转八进制   时间限制:1.0s   内存限制:512.0MB        锦囊1: 使用二进制.   问题描述 给定n个十六进制正整数,输出它们对应的八进制数. 输入格式 输入的 ...

  5. LAN8710A/LAN8710Ai datasheet 记录

    因为产品的双网口出现了问题,而且是AM335x 内部驱动,难度比较大,现从PHY 端开始分析相关原理,找到双网口不能使用的原因. 此篇是记录一些有关LAN8710A 这个PHY的一些特性. 各个功能模 ...

  6. CentOS 6编译安装yum和配置常用的yum源

    安装环境:VPS,CentOS 6 + devel包 一.安装相应的软件 1.安装python 下载Python源码包 [root@akinlau ~]# wget http://www.python ...

  7. 在linux上安装redmine

    Redmine 是一个开源的.基于Web的项目管理和缺陷跟踪工具.它用日历和甘特图辅助项目及进度可视化显示.同时它又支持多项目管理.Redmine是一个自由开放 源码软件解决方案,它提供集成的项目管理 ...

  8. archdexls主题设置每页显示游戏数目

    archdexls主题,沒调整前,每页显示10个,这显然不够,尤其在搜狗浏览器上,由于这个主题只有触发下拉滚动条,才会自动在同一页面显示下一页,因此只显示10个甚至不能触发显示下一页这个动作. 原来设 ...

  9. 在使用R做数据挖掘时,最常用的数据结构莫过于dataframe了,下面列出几种常见的dataframe的操作方法

    原网址 http://blog.sina.com.cn/s/blog_6bb07f83010152z0.html 在使用R做数据挖掘时,最常用的数据结构莫过于dataframe了,下面列出几种常见的d ...

  10. Windoows窗口程序四

    子窗口的创建 .创建时要设置父窗口句柄 .创建风格要增加WS_CHILD|WS_VISIBLE HWND CreateChild(LPSTR lpClassName,LPSTR lpWndName,H ...