ZooKeeper的API操作(二)(通俗易懂)
所需要6个jar包,都是解压zookeeper的tar包后里面的。
zookeeper-3.4.10.jar jline-0.094.jar log4j-1.2.16.jar
netty-3.10.5.jar slf4j-api-1.6.1.jar slf4j-log4j12-1.6.1.jar
1.建立连接
/**
* connectString : zk服务器连接ip和端口,多个用逗号隔开
* sessionTimeout : 连接超时时间
* watcher : 监听器(当被监控的节点发生改变时,zk会通过watcher传递给我们)
*/
#ZooKeeper zkCli = new ZooKeeper(connectString,sessionTimeout,watcher );
ZooKeeper zkCli = new ZooKeeper("192.168.199.15:2181,192.168.199.16:2181", 2000, new Watcher() {
@Override
public void process(WatchedEvent event) {
System.out.println("节点:"+event.getPath()+"发生了事件:"+event.getType());
}
});
2.创建节点
public void testCreateNode() throws Exception {
/**
* path :节点创建的路径
* data :节点创建要保存的数据,是个byte类型的
* acl :节点创建的权限信息(4种类型)
* ANYONE_ID_UNSAFE : 表示任何人
* AUTH_IDS :此ID仅可用于设置ACL。它将被客户机验证的ID替换。
* OPEN_ACL_UNSAFE :这是一个完全开放的ACL(常用)
* CREATOR_ALL_ACL :此ACL授予创建者身份验证ID的所有权限
* createMode :创建节点的类型(4种类型)
* PERSISTENT:永久节点
* EPHEMERAL:临时节点
* PERSISTENT_SEQUENTIAL:永久节点、序列化
* EPHEMERAL_SEQUENTIAL:临时节点、序列化
*/
# String node = zkCli.create(path,data,acl,createMode);
String node_PERSISTENT = zkCli.create("/zpb", "zk创建节点".getBytes("utf-8"), Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
String node_EPERSISTENT = zkCli.create("/zpb/zk", "2181".getBytes(), Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL);
System.out.println("创建的永久节点是:"+node_PERSISTENT);
System.out.println("创建的临时节点是:"+node_EPERSISTENT);
Thread.sleep(Long.MAX_VALUE); //查看临时节点时,防止zkCli退出
}
另:通过连接服务器端用命令查看结果:


备注:客户端创建永久节点时,zkCli 与服务端断开连接后,查看节点信息是存在的,反之临时节点与服务器断开连接后是不存在的
3.获取节点数据
public void getNodeData() throws Exception {
/**
* path : 获取数据的路径
* watch : 是否开启监听
* stat : 查看哪个版本的数据(节点上可能会保存多个版本的数据)
* null: 表示获取最新版本的数据
*
*
*/
#zkCli.getData(path, watch, stat);
byte[] data = zkCli.getData("/zpb", true, null);
System.out.println(new String(data,"utf-8"));
}
4.修改节点数据
public void testUpdateNodeData() throws Exception {
/**
* path : 修改节点的路径
* data : 要修改的数据
* version :修改哪个版本的数据
* -1: 匹配所有版本
*/
// zkCli.setData(path, data, version)
①详见建立连接;
②byte[] data = zkCli.getData("/zpb", true, null);
System.out.println("修改之前的数据是:"+new String(data,"utf-8"));
③Stat setData = zkCli.setData("/zpb", "zk修改节点".getBytes("utf-8"), -1);
④data = zkCli.getData("/zpb", true, null);
System.out.println("修改之后的数据是:"+new String(data,"utf-8"));
}
输出的结果:
节点:null发生了事件:None
修改之前的数据是:zk创建节点
节点:/zpb发生了事件:NodeDataChanged
修改之后的数据是:zk修改节点
执行顺序:
在创建客户端成功后,有1个Watcher事件,然后打印输出,当zkCli获取数据时设置了监听该节点的数据true,接着输出修改之前的数据,当zkCli修改数据后,
负责监听的watcher事件被触发,zkCli再次获取修改后的数据,并再次设置监听
5.删除节点
public void testDel() throws Exception {
// zkCli.delete(path, version);
Stat exists_1 = zkCli.exists("/zpb", true);
System.out.println(exists_1 == null ? "节点被删除了" : "节点没有被删除");
zkCli.delete("/zpb", -1); //-1表示匹配所有版本
Stat exists_2 = zkCli.exists("/zpb", true);
System.out.println(exists_2 == null ? "节点被删除了" : "节点没有被删除");
}
ZooKeeper的API操作(二)(通俗易懂)的更多相关文章
- ZooKeeper 原生API操作
zookeeper客户端和服务器会话的建立是一个异步的过程,也就是说在程序中,程序方法在处理完客户端初始化后立即返回(即程序继续往下执行代码,这样,在大多数情况下并没有真正的构建好一个可用会话,在会话 ...
- 五、Zookeeper基于API操作Node节点
安装zookeeper :linux下安装Zookeeper 3.4.14 zookeeper 分为5个包: org.apache.zookeeper //客户端主要类文件 org.apache.zo ...
- Azure Cosmos DB (二) SQL API 操作
一,引言 还记得国庆期间,我们学习了一下关于Azure Cosmos DB 的一些基础知识以及Azure Cosmos DB 的几种支持数据库类型.今天就开始分享一些实战操作,如何通过Azure Po ...
- Zookeeper C API 指南三(回调函数)(转)
2013-02-21 12:54 by Haippy, 9237 阅读, 0 评论, 收藏, 编辑 接上一篇<Zookeeper C API 指南二(监视(Wathes), 基本常量和结构体介绍 ...
- 六、Java API操作zookeeper节点
目录 前文 pom.xml文件增加依赖 新建java文件:ZookeeperTest GitHub文件下载 前文 一.CentOS7 hadoop3.3.1安装(单机分布式.伪分布式.分布式 二.JA ...
- zookeeper学习系列:二、api实践
上一章我们知道zookeeper的简介,启动,设置节点以及结构性能.本小节我们来玩玩api,获取下数据. php版本: http://anykoro.sinaapp.com/2013/04/05/%E ...
- zookeeper的java api操作
zookeeper的java api操作 创建会话: Zookeeper(String connectString,int sessionTimeout,Watcher watcher) Zookee ...
- zookeeper client API实现(python kazoo 的实现)
这里主要分析zookeeper client API的实现方式,以python kazoo的实现代码为蓝本进行逻辑分析. 一.代码框架及介绍 API分为同步模式和异步模式.同步模式是在异步模式的基础上 ...
- 9. 使用ZooKeeper Java API编程
ZooKeeper是用Java开发的,3.4.6版本的Java API文档可以在http://zookeeper.apache.org/doc/r3.4.6/api/index.html上找到. Ti ...
随机推荐
- Ubutun使用记录——语系错误(转)
add by zhj: 对原文有修改,原文是在创建用户时出现的问题,而我是在使用psql时出现的, 但问题是相同的. 原文:http://www.douban.com/note/362250557/ ...
- return的结果
return只会返回第一个,接下去的不会再返回 所以return放在for里面用的话,即使循环好几次,但是除了循环的第一个,后面循环出来的结果都作废
- PAT 1099 Build A Binary Search Tree[BST性质]
1099 Build A Binary Search Tree(30 分) A Binary Search Tree (BST) is recursively defined as a binary ...
- MySQL整理(一)
一.数据管理发展阶段 人工管理阶段→文件系统阶段→数据库系统阶段 二.数据库管理系统提供的功能 (1)数据定义语言DDL:提供数据定义语言定义数据库及各种对象,定义数据的完整性约束和保密限制 ...
- C++实现不能继承的类
实现一个不能继承的类,这在Java等语言中是很好实现的,被final关键字修饰的类不能被继承. C++中没有类似的关键字,须自己实现.一般有如下两种方法: 1.设置构造方法与析构方法为私有 class ...
- 三张图看遍Linux性能监控、测试、优化工具
Linux 平台上的性能工具有很多,眼花缭乱,长期的摸索和经验发现最好用的还是那些久经考验的.简单的小工具.系统性能专家 Brendan D. Gregg在最近的 LinuxCon NA 2014 大 ...
- 【Linux学习】3.Linux常见配置文件
一./etc 配置文件/etc/passwd 用户数据库,其中的域给出了用户名.真实姓名.家目录.加密口令和用户的其他信息 /etc/group 类似/etc/passwd ,但说明的不是用户而是组. ...
- 在VS2012中采用C++中调用DLL中的函数(4)
转自:http://www.cnblogs.com/woshitianma/p/3683495.html 这两天因为需要用到VS2012来生成一个DLL代码,但是之前并没有用过DLL相关的内容,从昨天 ...
- CF1155D Beautiful Array(动态规划)
做法 \(f_{i,0}\)表示以\(i\)结尾未操作时的最大值 \(f_{i,1}\)表示以\(i\)结尾正在操作时的最大值 \(f_{i,2}\)表示以\(i\)结尾已结束操作时的最大值 Code ...
- APP接口版本不兼容怎么办? 教你一招
现在基本每个公司都做APP,所以大家都面临 APP接口版本兼容的问题. iOS和android 要不断开发新版本,很多服务端开发都是在以前接口的逻辑上进行修改.新的APP和接口开发后,接口如何兼容老的 ...