zkClient的使用
ZKClient是由DataMeer的工程师StefanGroschupf和Peter Voss 一起开发的,在源生API接口基础上进行了封装,简化了ZK的复杂性。
1、 创建客户端方法:ZKClient(Arguments)
参数1:zkServers zookeeper服务器的地址,用“,”分割
参数2:session Timeout超时会话,为毫秒,默认为30 000ms
参数3:connection Timeout 连接超时会话
参数4:IZKConnection接口实现类
参数5:zkSerializer自定义序列化实现、
2、创建节点方法:
create、createEphemeral 、createEphemeralSequential、
createPersistent、createPersistentSequential
参数1: path 路径
参数2: data 数据内容 可以为null
参数3:mode 节点类型,为一个枚举类型,4种形式
参数4: acl策略
参数5: callback回调函数
参数6:context 上下文对象
参数7: createParents 是否创建父节点
3、删除节点方法delete deleteRecursive
参数1:path路径
参数2:callback 回调函数
参数3:context 上下文对象
4、读取子节点数据方法:getChildren
参数1:path路径
5、读取节点数据方法:readData
参数1:path路径
参数2:returnNUllLfPathNotExists(避免为空节点抛出异常,直接返回null)
参数3:节点状态
6、更新数据方法writeData
参数1:path 路径
参数2:data数据信息
参数3:version版本号
package bjsxt.zkclient.base; import java.util.List;
import java.util.concurrent.TimeUnit; import org.I0Itec.zkclient.ZkClient;
import org.I0Itec.zkclient.ZkConnection; public class ZkClientBase { /** zookeeper地址 */
static final String CONNECT_ADDR = "192.168.1.171:2181,192.168.1.172:2181,192.168.1.173:2181";
/** session超时时间 */
static final int SESSION_OUTTIME = 5000;//ms public static void main(String[] args) throws Exception {
ZkClient zkc = new ZkClient(new ZkConnection(CONNECT_ADDR), 5000);
//1. create and delete方法
zkc.createEphemeral("/temp");
zkc.createPersistent("/super/c1", true);
Thread.sleep(10000);
zkc.delete("/temp");
zkc.deleteRecursive("/super"); //2. 设置path和data 并且读取子节点和每个节点的内容
// zkc.createPersistent("/super", "1234");
// zkc.createPersistent("/super/c1", "c1内容");
// zkc.createPersistent("/super/c2", "c2内容");
// List<String> list = zkc.getChildren("/super");
// for(String p : list){
// System.out.println(p);
// String rp = "/super/" + p;
// String data = zkc.readData(rp);
// System.out.println("节点为:" + rp + ",内容为: " + data);
// } //3. 更新和判断节点是否存在
// zkc.writeData("/super/c1", "新内容");
// System.out.println(zkc.readData("/super/c1"));
// System.out.println(zkc.exists("/super/c1")); //4.递归删除/super内容
// zkc.deleteRecursive("/super");
}
}
7、检测节点是否存在方法 exists
参数1:path
我们发现。上述ZkClient里面并没有类似的watcher,watch参数,这也就是说我们开发人员无需关心反复注册Watcher的问题,ZkClient给我们提供了一套监听方式,我们可以使用监听节点的方式进行操作,剔除了繁琐的反复wather操作,简化了代码复杂程度、
8、subscribeChildChanges方法
参数1:path路径
参数2:实现了lZkChildListener接口的类(如:实例化lZkChildListener类)
只需要重写其handleChildChanges(String parentPath,List<String> currentChilds)方法,其中参数parentPath 为所监听节点全路径,
currentChilds为最新的子节点列表(相对路径)
lZkChildListener事件说明针对于下面三个事件触发:
新增子节点,减少子节点,删除节点
lZkChildListener有以下特点:
1、客户端可以对一个不存在的节点进行变更的监听
2、一旦客户端对一个节点注册了子节点列表变更监听后,那么当前节点的子节点列表发送变更的时候,服务器端都会通知客户端,并将最新的子节点列表发给客户端
3、该节点本身创建或删除也会通知到客户端
4、这个监听一直存在,不是单次监听,比元素API简单
package bjsxt.zkclient.watcher; import java.util.List; import org.I0Itec.zkclient.IZkChildListener;
import org.I0Itec.zkclient.ZkClient;
import org.I0Itec.zkclient.ZkConnection; public class ZkClientWatcher1 { /** zookeeper地址 */
static final String CONNECT_ADDR = "192.168.1.171:2181,192.168.1.172:2181,192.168.1.173:2181";
/** session超时时间 */
static final int SESSION_OUTTIME = 5000;//ms public static void main(String[] args) throws Exception {
ZkClient zkc = new ZkClient(new ZkConnection(CONNECT_ADDR), 5000); //对父节点添加监听子节点变化。
zkc.subscribeChildChanges("/super", new IZkChildListener() {
@Override
public void handleChildChange(String parentPath, List<String> currentChilds) throws Exception {
System.out.println("parentPath: " + parentPath);
System.out.println("currentChilds: " + currentChilds);
}
}); Thread.sleep(3000); zkc.createPersistent("/super");
Thread.sleep(1000); zkc.createPersistent("/super" + "/" + "c1", "c1内容");
Thread.sleep(1000); zkc.createPersistent("/super" + "/" + "c2", "c2内容");
Thread.sleep(1000); zkc.delete("/super/c2");
Thread.sleep(1000); zkc.deleteRecursive("/super");
Thread.sleep(Integer.MAX_VALUE); }
}
package bjsxt.zkclient.watcher; import org.I0Itec.zkclient.IZkDataListener;
import org.I0Itec.zkclient.ZkClient;
import org.I0Itec.zkclient.ZkConnection; public class ZkClientWatcher2 { /** zookeeper地址 */
static final String CONNECT_ADDR = "192.168.1.171:2181,192.168.1.172:2181,192.168.1.173:2181";
/** session超时时间 */
static final int SESSION_OUTTIME = 5000;//ms public static void main(String[] args) throws Exception {
ZkClient zkc = new ZkClient(new ZkConnection(CONNECT_ADDR), 5000); zkc.createPersistent("/super", "1234"); //对父节点添加监听子节点变化。
zkc.subscribeDataChanges("/super", new IZkDataListener() {
@Override
public void handleDataDeleted(String path) throws Exception {
System.out.println("删除的节点为:" + path);
} @Override
public void handleDataChange(String path, Object data) throws Exception {
System.out.println("变更的节点为:" + path + ", 变更内容为:" + data);
}
}); Thread.sleep(3000);
zkc.writeData("/super", "456", -1);
Thread.sleep(1000); zkc.delete("/super");
Thread.sleep(Integer.MAX_VALUE); }
}
zkClient的使用的更多相关文章
- ZooKeeper:第三方客户端 ZKClient
ZKClient ZKClient的设计 ZKClient组件说明 重要的处理流程说明 启动ZKClient 为节点注册Watcher ZooKeeper的变更操作 客户端处理变更 序列化处理 ZKC ...
- zookeeper_service 出错 java.lang.NoClassDefFoundError: org/I0Itec/zkclient/exception/ZkNoNodeException
2016-12-18 08:28:07 ContextLoader:358 ERROR - Context initialization failed java.lang.NoClassDefFoun ...
- (原) 2.2 ZkClient使用
本文为原创文章,转载请注明出处,谢谢 ZkClient使用 1.jar包引入,演示版本为0.8,非maven项目,可以下载jar包导入到项目中 <dependency> <group ...
- zkclient
zkclient 快速指南 Maven依赖 最新的版本发布在Maven中央库. <dependency> <groupId>com.github.adyliu</grou ...
- 为什么dubbo使用ZkClient作为zookeeper的客户端
本文内容并非原创,使用资料均来自互联网. dubbo使用了zkClient而不是使用zookeeper本身的客户端与zookeeper进行交互,为什么呢? 先看看zookeeper本身自带的客户端的问 ...
- 基于库zkclient 的leader选举代码实现
利用了zookeeper临时节点,在当连接或session断掉时被删除这一特性来做选举.(简单简单互斥锁) 查了下网上的做法. 大致流程: <1>判定是否存在/wzgtest路径 < ...
- 面向服务的体系架构 SOA(三) --- Zookeeper API、zkClient API的使用
zookeeper简单介绍及API使用 1.1 zookeeper简介 zookeeper是一个针对大型分布式系统的可靠的协调系统,提供的功能包括配置维护.名字服务.分布式同步.组服务等.zookee ...
- java.lang.ClassNotFoundException: org.I0Itec.zkclient.IZkStateListener异常解决
在启动Dubbo项目时,出现该异常 java.lang.ClassNotFoundException: org.I0Itec.zkclient.IZkStateListener 解决,引入 <d ...
- Exception in thread "main" org.I0Itec.zkclient.exception.ZkAuthFailedException: Authentication failure is thrown while creating kafka topic
Exception in thread "main" org.I0Itec.zkclient.exception.ZkAuthFailedException: Authentica ...
- zkclient中包引用不对,导致NoSuchMethodError
nidonglin commented on 31 Oct 2014 Exception in thread "main" java.lang.NoSuchMethodError: ...
随机推荐
- js 弹窗的实现
原理: 1. 点击按钮,触发窗口显示,遮罩层显示,并设置窗口的位置 2. 为弹出的窗口绑定鼠标滚动事件和视窗改变事件 3.点击关闭按钮,弹窗消失,遮罩层消失 html 代码: <!DOCTYPE ...
- Linux主机如何用ssh去登录docker容器的步骤
进入终端,sudo -i,切换root,输入docker -d 打开另一个终端,切换root,输入docker search ubuntu,大概如下结果: NAME ...
- RTS寻路相关资料收集
http://www.cocoachina.com/game/20150824/13174.html RVO算法 RVO避开agent
- harbor仓库镜像的删除
harbor仓库镜像的删除 刚开始自己摸索了下,直接webui界面删除后,发现仓库空间未释放 上传之前仓库空间占用为 上传之后仓库空间占用为 在webui界面上删除镜像后 查看大小 依旧为286m,到 ...
- React/anu实现Touchable
在RN中有一个叫Touchable 的组件,这里我们重演如何实现它. Touchable存在的意义是屏蔽click的问题.移动端与手机的click 在一些浏览器是有差异,比如说著名的300ms延迟. ...
- 二级菜单(avalon+jquery动画)
by 司徒正美 var vm = avalon.define({ $id: "test", array: [ { name: 111111, child: [ {name: 1.1 ...
- Todolist功能开发
一.属性绑定和双向数据绑定: v-bind:title 或简写成 :title实现title属性绑定: v-model实现双向数据绑定(双向是指:当数据变了,input的value会改变:当input ...
- 如何进行SQL排序
order by 语法如下: SELECT "栏位名" FROM "表格名" [WHERE "条件"] ORDER BY "栏位名 ...
- Mysql数据库如何创建用户
创建test用户,密码是1234. MySQL u root -p CREATE USER 'test'@'localhost' IDENTIFIED BY '1234'; #本地登录 CREATE ...
- python实现根据指定字符截取对应的行的内容
工作中遇到的,在一个.c文件中有很多函数,这个.c是自动生成的,需要将所有的函数通过extern放到.h中,每个函数都是UINT32 O_开头,通过正则表达式进行字符匹配以及通过linecache来截 ...