Zookeeper客户端使用

一、使用原生zookeeper

在pom.xml中加入依赖

<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.13</version>
</dependency>

直接上代码:

 /**
* Project Name:mk-project <br>
* Package Name:com.suns.zookeeper <br>
*
* @author mk<br>
* Date:2018-10-31 9:09 <br>
*/ package com.suns.zookeeper; import org.apache.zookeeper.*;
import org.apache.zookeeper.data.Stat; import java.util.List;
import java.util.concurrent.CountDownLatch; /**
* 原生的zookeeper客户端
* 1.连接是异步的,使用时需要注意。增加watcher,监听事件如果为SyncConnected,那么才做其他的操作。(利用CountDownLatch控制)
* 2.监听事件是一次性的,如果操作多次需要注册多次(可以通过getData等方法)
* ClassName: ZookeeperNative <br>
* Description: <br>
* @author mk
* @Date 2018-10-31 9:09 <br>
* @version
*/
public class ZookeeperNative { public static final String connect = "127.0.0.1:2181";
private static ZooKeeper zookeeper = null;
private static CountDownLatch cdl = new CountDownLatch(0);
private static String nodePath = "/native1";
private static String nodeChildPath = "/native1/n1/n11/n111/n1111"; public static void main(String[] args) throws Exception { //初始化
init(connect,5000); //新增
create(nodePath,"n1");
//递归新增
createRecursion(nodeChildPath,"n1"); //查询
query(nodePath); //修改
update(nodePath,"n11"); //单个节点删除
// delete(nodePath);
//递归删除
deleteRecursion(nodePath);
} private static void deleteRecursion(String nodePath) throws KeeperException, InterruptedException {
Stat exists = zookeeper.exists(nodePath, true);
if(null == exists){
System.out.println(nodePath+"不存在");
return ;
} List<String> list = zookeeper.getChildren(nodePath, true);
if(null == list || list.size() == 0){
delete(nodePath);
String parentPath = nodePath.substring(0,nodePath.lastIndexOf("/"));
System.out.println("parentPath="+parentPath);
if(!"".equals(parentPath)){
deleteRecursion(parentPath);
}
}else{
for(String child : list){
deleteRecursion(nodePath+"/"+child);
}
}
} private static void delete(String path) throws KeeperException, InterruptedException {
query(path);//为了让watcher能被监听,在这里查询一次
zookeeper.delete(path,-1);
System.out.println("delete:"+"["+path+"]");
} private static void update(String path, String data) throws KeeperException, InterruptedException {
Stat stat = zookeeper.setData(path, data.getBytes(), -1);//versoin=-1代表不记录版本
System.out.println("setData:"+"["+path+"],stat:"+stat);
} private static void query(String path) throws KeeperException, InterruptedException {
Stat stat = new Stat();
byte[] data = zookeeper.getData(path, true, stat);
System.out.println("query:"+"["+path+"],result:"+new String(data) + ",stat:"+stat);
} private static void createRecursion(String path,String data) throws KeeperException, InterruptedException {
if(null == path || "".equals(path)){
System.out.println("节点["+path+"]为空");
return;
}
String paths[] = path.substring(1,path.length()).split("/");
for(int i=0;i<paths.length;i++){
String childPath = "";
for(int j=0;j<=i;j++){
childPath += "/" + paths[j];
}
create(childPath,data);
} Stat exists = zookeeper.exists(path, true);
if(null != exists){
System.out.println("节点["+path+"]已存在,不能新增");
return;
}
String result = zookeeper.create(path, data.getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
System.out.println("create:"+"["+path+"-->"+data+"],result:"+result);
} private static void create(String path,String data) throws KeeperException, InterruptedException {
Stat exists = zookeeper.exists(path, true);
if(null != exists){
System.out.println("节点["+path+"]已存在,不能新增");
return;
}
String result = zookeeper.create(path, data.getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
System.out.println("create:"+"["+path+"-->"+data+"],result:"+result);
} private static void init(final String connectStr, int sessionTimeout) throws Exception {
// zookeeper = new ZooKeeper(connectStr, sessionTimeout, null);
//由于zookeeper连接是异步的,如果new ZooKeeper(connectStr, sessionTimeout, null)完之后马上使用,有可能会报错。
//解决办法:增加watcher,监听事件如果为SyncConnected,那么才做其他的操作。(利用CountDownLatch控制)
zookeeper = new ZooKeeper(connectStr, sessionTimeout, new Watcher() {
@Override
public void process(WatchedEvent watchedEvent) {
if(watchedEvent.getState() == Event.KeeperState.SyncConnected) {
// System.out.println("zookeeper已连接["+connectStr+"]成功");
cdl.countDown();
}
if(watchedEvent.getType() == Event.EventType.NodeCreated){
System.out.println("zookeeper有新节点创建"+watchedEvent.getPath());
}
if(watchedEvent.getType() == Event.EventType.NodeDataChanged){
System.out.println("zookeeper有节点数据变化"+watchedEvent.getPath());
}
if(watchedEvent.getType() == Event.EventType.NodeDeleted){
System.out.println("zookeeper有节点被删除"+watchedEvent.getPath());
}
if(watchedEvent.getType() == Event.EventType.NodeChildrenChanged){
System.out.println("zookeeper有子节点变化"+watchedEvent.getPath());
}
}
});
cdl.await();
System.out.println("init start :" +zookeeper);
} }

运行结果:

Zookeeper客户端使用(使用原生zookeeper)的更多相关文章

  1. Zookeeper系列三:Zookeeper客户端的使用(Zookeeper原生API如何进行调用、ZKClient、Curator)和Zookeeper会话

    一.Zookeeper原生API如何进行调用 准备工作: 首先在新建一个maven项目ZK-Demo,然后在pom.xml里面引入zk的依赖 <dependency> <groupI ...

  2. ZooKeeper客户端原生API的使用以及ZkClient第三方API的使用

    这两部分内容的介绍主要讲的是节点及节点内容和子节点的操作,并且讲解的节点的事件监听以及ACL授权 ZooKeeper客户端原生API的使用 百度网盘地址: http://pan.baidu.com/s ...

  3. Zookeeper客户端使用(使用Curator)

    Zookeeper客户端(使用Curator) 三.使用curator客户端 在pom.xml中加入依赖 <dependency> <groupId>org.apache.cu ...

  4. Zookeeper客户端使用(使用zkclient)

    Zookeeper客户端使用 二.使用zkclient 在pom.xml中加入依赖 <dependency> <groupId>com.101tec</groupId&g ...

  5. zookeeper客户端使用原生JavaApi操作节点

    1.引入依赖 <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId>zook ...

  6. Zookeeper客户端Curator基本API

    在使用zookeper的时候一般不使用原生的API,Curator,解决了很多Zookeeper客户端非常底层的细节开发工作,包括连接重连.反复注册Watcher和NodeExistsExceptio ...

  7. Zookeeper客户端Curator的使用,简单高效

    Curator是Netflix公司开源的一个Zookeeper客户端,与Zookeeper提供的原生客户端相比,Curator的抽象层次更高,简化了Zookeeper客户端的开发量. 1.引入依赖: ...

  8. Zookeeper客户端Curator使用详解

    Zookeeper客户端Curator使用详解 前提 最近刚好用到了zookeeper,做了一个基于SpringBoot.Curator.Bootstrap写了一个可视化的Web应用: zookeep ...

  9. 7.5 zookeeper客户端curator的基本使用 + zkui

    使用zookeeper原生API实现一些复杂的东西比较麻烦.所以,出现了两款比较好的开源客户端,对zookeeper的原生API进行了包装:zkClient和curator.后者是Netflix出版的 ...

随机推荐

  1. 1.2.1 Maven到底是什么鬼

    解释之前,提1个小问题. 1.1.假如你正在Eclipse下开发两个Java项目,姑且把它们称为A.B,其中A项目中的一些功能依赖于B项目中的某些类,那么如何维系这种依赖关系的呢? 很简单,这不就是跟 ...

  2. Android Studio设置国内镜像代理

    点击主面板右下角的Configure –> settings –> Appearance & Behavior –> System Settings –> HTTP P ...

  3. 使用bloomfilter

    package bloom; /** * 项目名:SpiderCrawler * 文件名:BloomFilterTest.java * 作者:zhouyh * 时间:2014-8-29 下午02:54 ...

  4. Tomcat常见启动问题

    1)闪退问题 原因:tomcat软件是java语言开发的. tomcat软件启动时,会默认到系统的环境变量中查找一个名称叫JAVA_HOME的变量.这个变量的作用找到tomcat启动所需的jvm. 解 ...

  5. 解决打开AS多次提示Untrusted Server's certificate问题

    解决方法如下: 打开Studio左上角的file—>Setting-->Tools-->Server Certificates ->最后勾上 Accept non-truste ...

  6. ddms 和 traceview 的区别?

    ddms 原意是:davik debug monitor service.简单的说 ddms 是一个程序执行查看器,在里面可以看见线程和堆栈等信息,traceView 是程序性能分析器.tracevi ...

  7. flutter ListView嵌套高度问题

    ListView嵌套时高度无法自适应,需要设置高度才可以显示,设置以下属性可以解决上述问题 shrinkWrap: true, physics: NeverScrollableScrollPhysic ...

  8. 阶段3 2.Spring_01.Spring框架简介_01.spring课程四天安排

    spring共四天 第一天:spring框架的概述以及spring中基于XML的IOC配置 第二天:spring中基于注解的IOC和ioc的案例 第三天:spring中的aop和基于XML以及注解的A ...

  9. JavaScript 积累

    1. 基本类型值在内存中占据固定大小的空间,因此被保存在栈空间中: 2. 引用类型的值是对象,保存在堆空间中: 3. 从一个变量向另一个变量复制基本类型的值,会创建这个值的一个副本:从一个变量向另一个 ...

  10. Day03:数组 、 继承的意义(上)

    继承 面向对象编程三(四)大特征 (抽象),封装,继承,多态什么是继承? 继承是面向对象编程中一种代码复用的方式为什么需要继承? 减少代码冗余,提高程序的可维护性和可扩展性怎样使用继承? 语法: cl ...