本文主要介绍如何在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 简单操作示例的更多相关文章

  1. zookeeper JAVA API 简单操作

    package org.admln.program.Zoo_Test; import java.io.IOException; import java.security.NoSuchAlgorithm ...

  2. 9. 使用ZooKeeper Java API编程

    ZooKeeper是用Java开发的,3.4.6版本的Java API文档可以在http://zookeeper.apache.org/doc/r3.4.6/api/index.html上找到. Ti ...

  3. Phoenix简介概述,Phoenix的Java API 相关操作优秀案例

    Phoenix简介概述,Phoenix的Java API 相关操作优秀案例 一.Phoenix概述简介 二.Phoenix实例一:Java API操作 2.1 phoenix.properties 2 ...

  4. Zookeeper java api

     Zookeeper java api 主要有以下几个: 方法名称 描述 String create(final String path, byte data[], List acl, CreateM ...

  5. 14.ZooKeeper Java API 使用样例

    转自:http://www.aboutyun.com/thread-7332-1-1.html package com.taobao.taokeeper.research.sample; import ...

  6. github上创建java项目简单操作

    github上创建java项目简单操作 参考L: github上创建java项目简单操作 - CSDN博客http://blog.csdn.net/qq_29392425/article/detail ...

  7. 【ZooKeeper】ZooKeeper安装及简单操作

    ZooKeeper介绍 ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件.它是一个为分布式应用提供一 ...

  8. HDFS Java API 常用操作

    package com.luogankun.hadoop.hdfs.api; import java.io.BufferedInputStream; import java.io.File; impo ...

  9. zookeeper java api(使用java代码操作zookeeper)

    1 导入相关的pom依赖 <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId&g ...

随机推荐

  1. GCC手册学习(序)

    已经是2014年的年末了,又快过了一年.今年,一定要认真把GCC再学习一遍,做好笔记. 总览 gcc [option|filename] ... g++ [option|filename] ...   ...

  2. PHP之AOP思想

    故事背景: 问题: 在传统的OOP(面向对象编程:Object-Oriented Programming)思想里,一般把应用程序分解成若干个的对象,强调高内聚,弱耦合,从而提高应用程序的模块化程度,但 ...

  3. Atitit.预定义变量与变量预处理器

    Atitit.预定义变量与变量预处理器 1. 预定义变量与1 2. 变量预处理器1 3. 测试数据生成器3 1. 预定义变量与 姓名:$name 次数:$rdm 时间:$datetime 文件名:$f ...

  4. atitit.atiHtmlUi web组件化方案与规范v1

    atitit.atiHtmlUi web组件化方案与规范v1 1. 如何在现有html 标签基础上定义自己的组件1 2. 组件的构成与定义1 3. 组件的加载1 4. 组件css的加载2 5. 操作组 ...

  5. Java遍历包中所有类

    PackageUtil 类 import java.io.File; import java.net.URL; import java.net.URLClassLoader; import java. ...

  6. js模块化规范AMD、CMD、CommonJS...

    1. AMD 1.1 什么是AMD? AMD 英文名 Asynchronous Module Definition ,中文名 异步模块定义 .这是一个浏览器模块化开发的规范. 由于浏览器环境执行环境的 ...

  7. ECC加密算法原理入门介绍

    前言 同RSA(Ron Rivest,Adi Shamir,Len Adleman三位天才的名字)一样,ECC(Elliptic Curves Cryptography,椭圆曲线密码编码学)也属于公开 ...

  8. NGUI3.7.4实现循环拖动

    前段时间下了NGUI新版本3.7.4,看到例子Endless Scroll Views,实现了循环拖动,可能会用到,先把实现步骤贴出来跟大家分享一下. 1.首先新建一个背景. 2.添加所需控件,类似滑 ...

  9. PHP——smarty模板(做登录页面和主页面)

    denglu.php <?php include "init.inc.php"; $smarty->assign("action","ma ...

  10. RTT工程管理

    一.RTT工程管理 RTT采用SCons管理工程. 本次安装版本:Python-2.7.3.1.exe,python-2.7.11.msi,scons-2.3.1-setup.exe 安装完成后,需要 ...