zookeeper Java API 简单操作示例
本文主要介绍如何在java IDE中如何应用使用客户端与zookeeper服务器通信。
首先搭建maven环境,并在pom文件中加入zookeeper引用包:
<!-- https://mvnrepository.com/artifact/org.apache.zookeeper/zookeeper -->
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.9</version>
</dependency>
如果从maven中引用失败,也不比灰心,在官网上下载zookeeper-3.4.9.tar.gz包,解压后里面包含zookeeper-3.4.9.jar包,在工程中引入这个包即可。
在工程中新建TestZookeeper.java文件,代码如下:
package com.unionpay.zookeeperDemo; import java.io.IOException; import org.apache.zookeeper.CreateMode;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZooDefs.Ids;
import org.apache.zookeeper.ZooKeeper; public class TestZookeeper {
public static void main(String[] args){
ZooKeeper zk = null; try{
System.out.println("......");
System.out.println("Starting to connencting zookeeper......"); String connectString = "127.0.0.1:2181";
int sessionTimeout = 2000; Watcher watcher = new Watcher(){ @Override
public void process(WatchedEvent event) {
if(event.getType() == null || "".equals(event.getType())){
return;
}
System.out.println("已经触发了" + event.getType() + "事件!");
}
};
zk = new ZooKeeper(connectString, sessionTimeout, watcher); /* zk = new ZooKeeper(connectString, sessionTimeout, new Watcher(){
public void process(WatchedEvent event){
if(event.getType()==null | "".equals(event.getType())){
return;
}
System.out.println("已经触发了" + event.getType() + "事件!");
}
});*/ System.out.println("Zookeeper Connected Successfully!"); Thread.currentThread().sleep(10001); System.out.println("......");
System.out.println("开始创建根目录节点/tmp_root_path...");
zk.exists("/tmp_root_path", true);
zk.create("/tmp_root_path", "我是根目录节点/tmp_root_path".getBytes("utf-8"), Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
System.out.println("根目录节点/tmp_root_path创建成功"); Thread.currentThread().sleep(10001); System.out.println("......");
System.out.println("开始创建第一个子目录节点/tmp_root_path/childPath1...");
zk.exists("/tmp_root_path/childPath1", true);
zk.create("/tmp_root_path/childPath1", "我是第一个子目录/tmp_root_path/childPath1".getBytes("utf-8"), Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
System.out.println("第一个子目录节点/tmp_root_path/childPath1创建成功"); Thread.currentThread().sleep(10001); System.out.println("......");
System.out.println("开始修改第一个子目录节点/tmp_root_path/childPaht1的数据......");
//通过getData 或 exists 方法触发watcher事件
zk.getData("/tmp_root_path/childPath1", true, null);
zk.setData("/tmp_root_path/childPath1", "我是修改后的第一个子目录/tmp_root_path/childPath1".getBytes("utf-8"), -1);
//version参数指定要更新的数据版本,如果version和真实的版本数据不同,则更新操作失败,当setData中设置版本为-1时,忽略版本检测
System.out.println("修改第一个子目录节点/tmp_root_path/childPath1数据成功!"); Thread.currentThread().sleep(10001); System.out.println("......"); System.out.println("获取根目录节点状态......");
System.out.println(zk.exists("/tmp_root_path", true));
System.out.println("根目录节点获取成功"); Thread.currentThread().sleep(10001); System.out.println("......");
System.out.println("开始创建第二个子目录节点/tmp_root_path/childPath2...");
zk.exists("/tmp_root_path/childPath2", true);
zk.create("/tmp_root_path/childPath2", "我是第二个子目录节点/tmp_root_path/childPath2".getBytes("utf-8"), Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
System.out.println("第二个子目录节点/tmp_root_path/childPath2创建成功"); Thread.currentThread().sleep(10001); System.out.println("......");
System.out.println("获取第二个子目录节点数据......");
System.out.println(new String(zk.getData("/tmp_root_path/childPath2", true, null)));
System.out.println("成功获取第二个子目录节点数据"); Thread.currentThread().sleep(10001); System.out.println("......");
System.out.println("开始获取根目录节点状态");
System.out.println(zk.exists("/tmp_root_path", true));
System.out.println("根目录节点状态获取成功"); Thread.currentThread().sleep(10001); System.out.println("开始删除第一个子目录节点/tmp_root_path/childPath1...");
/*zk.getData("/tmp_root_path/childPath1", true, null);*/
zk.exists("/tmp_root_path/childPath1", true);
zk.delete("/tmp_root_path/childPath1", -1);
System.out.println("第一个子目录节点/tmp_root_path/childPath1删除成功"); Thread.currentThread().sleep(10001); System.out.println("开始获取根目录节点状态");
System.out.println(zk.exists("/tmp_root_path", true));
System.out.println("根目录节点状态获取成功"); Thread.currentThread().sleep(10001); System.out.println("开始删除第二个子目录节点/tmp_root_path/childPath2......");
zk.delete("/tmp_root_path/childPath2", -1);
System.out.println("第二个子目录节点/tmp_root_path/childPath2删除成功"); Thread.currentThread().sleep(10001); System.out.println("......");
System.out.println("开始获取根目录节点状态");
System.out.println(zk.exists("/tmp_root_path", true));
System.out.println("根目录节点状态获取成功"); Thread.currentThread().sleep(10001); System.out.println("开始删除根目录节点/tmp_root_path......");
zk.delete("/tmp_root_path", -1);
System.out.println("删除根目录节点/tmp_root_path成功"); Thread.currentThread().sleep(10001);
System.out.println("查看根目录节点状态");
System.out.println(zk.exists("/tmp_root_path", true));
System.out.println("根目录节点状态获取成功"); Thread.currentThread().sleep(10001);
}catch(IOException | KeeperException | InterruptedException e){
e.printStackTrace();
}finally{
if(zk != null){
try{
zk.close();
System.out.println("关闭Zookeeper连接成功");
}catch(InterruptedException e){
e.printStackTrace();
}
}
}
}
}
然后启动zookeeper服务器:
bash server1/bin/zkServer.sh start bash server2/bin/zkServer.sh start bash server3/bin/zkServer.sh start
当zookeeper集群成功启动后,运行TestZookeeper.java文件,运行结果如下:
......
Starting to connencting zookeeper......
log4j:WARN No appenders could be found for logger (org.apache.zookeeper.ZooKeeper).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
Zookeeper Connected Successfully!
已经触发了None事件!
......
开始创建根目录节点/tmp_root_path...
已经触发了NodeCreated事件!
根目录节点/tmp_root_path创建成功
......
开始创建第一个子目录节点/tmp_root_path/childPath1...
已经触发了NodeCreated事件!
第一个子目录节点/tmp_root_path/childPath1创建成功
......
开始修改第一个子目录节点/tmp_root_path/childPaht1的数据......
已经触发了NodeDataChanged事件!
修改第一个子目录节点/tmp_root_path/childPath1数据成功!
......
获取根目录节点状态......
30064771083,30064771083,1487902036450,1487902036450,0,1,0,0,35,1,30064771084 根目录节点获取成功
......
开始创建第二个子目录节点/tmp_root_path/childPath2...
已经触发了NodeCreated事件!
第二个子目录节点/tmp_root_path/childPath2创建成功
......
获取第二个子目录节点数据......
我是第二个子目录节点/tmp_root_path/childPath2
成功获取第二个子目录节点数据
......
开始获取根目录节点状态
30064771083,30064771083,1487902036450,1487902036450,0,2,0,0,35,2,30064771086 根目录节点状态获取成功
开始删除第一个子目录节点/tmp_root_path/childPath1...
已经触发了NodeDeleted事件!
第一个子目录节点/tmp_root_path/childPath1删除成功
开始获取根目录节点状态
30064771083,30064771083,1487902036450,1487902036450,0,3,0,0,35,1,30064771087 根目录节点状态获取成功
开始删除第二个子目录节点/tmp_root_path/childPath2......
已经触发了NodeDeleted事件!
第二个子目录节点/tmp_root_path/childPath2删除成功
......
开始获取根目录节点状态
30064771083,30064771083,1487902036450,1487902036450,0,4,0,0,35,0,30064771088 根目录节点状态获取成功
开始删除根目录节点/tmp_root_path......
已经触发了NodeDeleted事件!
删除根目录节点/tmp_root_path成功
查看根目录节点状态
null
根目录节点状态获取成功
关闭Zookeeper连接成功
在代码中,我们可以看到zk.exists("****",true),不断出现,目的是为了监听相应的znode 修改和删除事件,从结果中我们也不难看出监听结果“已经触发了NodeDataChanged事件!”和“已经触发了NodeDeleted事件!”。之所以要对每个节点多次执行zk.exists(),这是因为在zookeeper机制下,zk.exists()方法、zk.get()方法和zk.getChildren()方法仅仅监控对应节点的一次变化(数据变化或者子节点数目发生变化)。
zookeeper可以监控到的事件类型:
- ZOO_CREATED_EVENT:节点创建事件,需要watch一个不存在的节点,当此节点被创建时,通过exist()设置可以触发该对该事件的监控;
- ZOO_DELETED_EVENT:节点删除事件,此watch通过exists()或者get()设置监控;
- ZOO_CHANGED_EVENT:节点数据改变事件,此watch通过exists()或者get()设置监控;
- ZOO_CHILD_EVENT:子节点列表改变事件,此watch通过getChildren()设置监控;
- ZOO_SESSION_EVENT:会话失效事件,客户端与服务端断开或者重新连结时触发;
- ZOO_NOWATCHING_EVENT:watch移除事件,服务端因为某些原因不再为客户端watch节点的触发
参考文献:
zookeeper Java API 简单操作示例的更多相关文章
- zookeeper JAVA API 简单操作
package org.admln.program.Zoo_Test; import java.io.IOException; import java.security.NoSuchAlgorithm ...
- 9. 使用ZooKeeper Java API编程
ZooKeeper是用Java开发的,3.4.6版本的Java API文档可以在http://zookeeper.apache.org/doc/r3.4.6/api/index.html上找到. Ti ...
- Phoenix简介概述,Phoenix的Java API 相关操作优秀案例
Phoenix简介概述,Phoenix的Java API 相关操作优秀案例 一.Phoenix概述简介 二.Phoenix实例一:Java API操作 2.1 phoenix.properties 2 ...
- Zookeeper java api
Zookeeper java api 主要有以下几个: 方法名称 描述 String create(final String path, byte data[], List acl, CreateM ...
- 14.ZooKeeper Java API 使用样例
转自:http://www.aboutyun.com/thread-7332-1-1.html package com.taobao.taokeeper.research.sample; import ...
- github上创建java项目简单操作
github上创建java项目简单操作 参考L: github上创建java项目简单操作 - CSDN博客http://blog.csdn.net/qq_29392425/article/detail ...
- 【ZooKeeper】ZooKeeper安装及简单操作
ZooKeeper介绍 ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件.它是一个为分布式应用提供一 ...
- HDFS Java API 常用操作
package com.luogankun.hadoop.hdfs.api; import java.io.BufferedInputStream; import java.io.File; impo ...
- zookeeper java api(使用java代码操作zookeeper)
1 导入相关的pom依赖 <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId&g ...
随机推荐
- GCC手册学习(序)
已经是2014年的年末了,又快过了一年.今年,一定要认真把GCC再学习一遍,做好笔记. 总览 gcc [option|filename] ... g++ [option|filename] ... ...
- PHP之AOP思想
故事背景: 问题: 在传统的OOP(面向对象编程:Object-Oriented Programming)思想里,一般把应用程序分解成若干个的对象,强调高内聚,弱耦合,从而提高应用程序的模块化程度,但 ...
- Atitit.预定义变量与变量预处理器
Atitit.预定义变量与变量预处理器 1. 预定义变量与1 2. 变量预处理器1 3. 测试数据生成器3 1. 预定义变量与 姓名:$name 次数:$rdm 时间:$datetime 文件名:$f ...
- atitit.atiHtmlUi web组件化方案与规范v1
atitit.atiHtmlUi web组件化方案与规范v1 1. 如何在现有html 标签基础上定义自己的组件1 2. 组件的构成与定义1 3. 组件的加载1 4. 组件css的加载2 5. 操作组 ...
- Java遍历包中所有类
PackageUtil 类 import java.io.File; import java.net.URL; import java.net.URLClassLoader; import java. ...
- js模块化规范AMD、CMD、CommonJS...
1. AMD 1.1 什么是AMD? AMD 英文名 Asynchronous Module Definition ,中文名 异步模块定义 .这是一个浏览器模块化开发的规范. 由于浏览器环境执行环境的 ...
- ECC加密算法原理入门介绍
前言 同RSA(Ron Rivest,Adi Shamir,Len Adleman三位天才的名字)一样,ECC(Elliptic Curves Cryptography,椭圆曲线密码编码学)也属于公开 ...
- NGUI3.7.4实现循环拖动
前段时间下了NGUI新版本3.7.4,看到例子Endless Scroll Views,实现了循环拖动,可能会用到,先把实现步骤贴出来跟大家分享一下. 1.首先新建一个背景. 2.添加所需控件,类似滑 ...
- PHP——smarty模板(做登录页面和主页面)
denglu.php <?php include "init.inc.php"; $smarty->assign("action","ma ...
- RTT工程管理
一.RTT工程管理 RTT采用SCons管理工程. 本次安装版本:Python-2.7.3.1.exe,python-2.7.11.msi,scons-2.3.1-setup.exe 安装完成后,需要 ...