【Zookeeper构造方法概述】

/**
* 客户端和zk服务端的连接是一个异步的过程
* 当连接成功后,客户端会收到一个watch通知
*
* ZooKeeper(String connectString, int sessionTimeout, Watcher watcher,
* long sessionId, byte[] sessionPasswd, boolean canBeReadOnly)
* 参数介绍
* connectString:连接服务器的ip字符串
* 比如:"192.168.1.1:2181,192.168.1.2:2181,192.168.1.3:2181"
* 可以是一个ip,也可以是多个ip,一个ip代表单机,多个ip代表集群
* 也可以在ip后加路径
* sessionTimeout:超时时间,心跳收不到了,那就超时
* watcher:通知事件,如果有对应的事件触发,则会收到一个通知:如果不需要,那就设为null
* sessionId:会话的id
* sessionPasswd:会话密码,当会话丢失后,可以依据sessionId和sessionPasswd重新获取会话
* canBeReadOnly:可读,当这个物理机节点断开后,还是可以读到数据的,只是不能写,
* 此时数据被读取到的可能是旧数据,一般设置为false,不推荐使用
*
*/
public ZooKeeper(String connectString, int sessionTimeout, Watcher watcher, long sessionId, byte[] sessionPasswd, boolean canBeReadOnly)

【Zookeeper API 客户端连接服务端例子】

package com.zk.demo;

import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZooKeeper; /**
* Created by HigginCui on 2018/9/20.
*/
public class ZkConnect implements Watcher{ public static final String zkServerPath = "127.0.0.1:2181"; public static final Integer timeout = ; /**
* 客户端和zk服务端的连接是一个异步的过程
* 当连接成功后,客户端会收到一个watch通知
*/
public static void main(String[] args) throws Exception{
ZooKeeper zk = new ZooKeeper(zkServerPath,timeout,new ZkConnect()); for (int i=;i<;i++) {
Thread.sleep(); //休眠10ms,在这个过程中,连接状态会从CONNECTING--->CONNECTED
System.out.println(i+"---"+zk.getState());
} } @Override
public void process(WatchedEvent watchedEvent) {
System.err.println("收到zk的watch通知----" );
}
}

【运行结果】

【使用CountDownLatch优化zk连接过程】

package com.zk.demo;

import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZooKeeper; import java.util.concurrent.CountDownLatch; public class ZkConnect implements Watcher{ public static final String zkServerPath = "127.0.0.1:2181"; public static final Integer timeout = 5000; private static CountDownLatch latch = new CountDownLatch(1); public static void main(String[] args) throws Exception{
ZooKeeper zk = new ZooKeeper(zkServerPath,timeout,new ZkConnect()); System.out.println("连接状态---" + zk.getState());
latch.await();
System.out.println("连接状态---" + zk.getState()); } @Override
public void process(WatchedEvent watchedEvent) {
System.err.println("收到zk的watch通知----" );
latch.countDown();
}
}

【运行结果】

【创建节点】

/**
*
* String create(String path, byte[] data, List<ACL> acl, CreateMode createMode)
*
* 同步或异步创建节点,都不支持子节点的递归操作,异步有一个callBack方法
* 参数
* path:创建的路径
* data:存储的数据,byte[]类型
* acl:权限控制策略
* Ids.OPEN_ACL_UNSAFE ---> world:anyone:crdwa
* CREATE_ALL_ACL ---> auth:user:password:cdrwa
* createMode:节点类型,是一个枚举
* CreateMode.PERSISTENT: 持久节点
* CreateMode.PERSISTENT_SEQUENTIAL:持久顺序节点
* CreateMode.EPHEMERAL: 临时节点
* CreateMode.EPHEMERAL_SEQUENTIAL: 临时顺序节点
*/

【创建一个临时节点】

package com.zk.demo;

import org.apache.zookeeper.*;
import java.util.concurrent.CountDownLatch; /**
* Created by HigginCui on 2018/9/21.
*/
public class ZkNodeOperator implements Watcher{ private static ZooKeeper zooKeeper = null; public static final String zkServerPath = "127.0.0.1:2181"; public static final Integer timeout = 5000; private static CountDownLatch latch = new CountDownLatch(1); public ZkNodeOperator() {
} private static void init() {
try{
zooKeeper = new ZooKeeper(zkServerPath,timeout,new ZkNodeOperator());
latch.await();
}catch (Exception e){
e.printStackTrace();
if(zooKeeper!=null){
try {
zooKeeper.close();
}catch (InterruptedException e1){
e1.printStackTrace();
}
}
}
} public static void main(String[] args) throws Exception{
init();
      //创建/testnode临时节点,包含数据为haha,权限是OPEN_ACL_UNSAFE,类型为临时节点
zooKeeper.create("/testnode","haha".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE,CreateMode.EPHEMERAL);
} /**
* 观察者
*/
@Override
public void process(WatchedEvent event) {
System.err.println("收到zk的watch通知----" +event.getPath()+"---"+event.getState());
latch.countDown(); }
}

【运行结果 直接看打开zkCli.sh连接】

【创建持久节点,并且产生一个回调通知】

package com.zk.demo;

import org.apache.zookeeper.*;
import java.util.concurrent.CountDownLatch; /**
* Created by HigginCui on 2018/9/21.
*/
public class ZkNodeOperator implements Watcher{ private static ZooKeeper zooKeeper = null; public static final String zkServerPath = "127.0.0.1:2181"; public static final Integer timeout = 5000; private static CountDownLatch latch = new CountDownLatch(1); public ZkNodeOperator() {
} private static void init() {
try{
zooKeeper = new ZooKeeper(zkServerPath,timeout,new ZkNodeOperator());
latch.await();
}catch (Exception e){
e.printStackTrace();
if(zooKeeper!=null){
try {
zooKeeper.close();
}catch (InterruptedException e1){
e1.printStackTrace();
}
}
}
} public static void main(String[] args) throws Exception{
init();
//create(String path, byte[] data, List<ACL> acl, CreateMode createMode, StringCallback cb, Object ctx)
String ctx = "{'create':'success'}";
zooKeeper.create("/testnode","haha".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE,CreateMode.PERSISTENT,new CreateNodeCallBack(),ctx); System.in.read(); //线程停在这里,等待回调线程的打印结果
} /**
* 观察者
*/
@Override
public void process(WatchedEvent event) {
System.err.println("收到zk的watch通知----" +event.getPath()+"---"+event.getState());
latch.countDown(); }
} /**
* 创建节点回调通知类
*/
class CreateNodeCallBack implements AsyncCallback.StringCallback{
@Override
public void processResult(int i, String path, Object ctx, String s1) {
System.out.println("【回调方法】:创建节点的路径:"+path);
System.out.println("【回调方法】:ctx==="+(String)ctx);
}
}

【运行结果——控制台打印】

【运行结果——zk客户端连接】

【修改节点的数据】

/**
* path:节点路径
* data:修改后的数据
* version:版本号,这里的版本号必须是正要修改的节点数据的版本号!!
*/
Stat setData(String path, byte[] data, int version)

修改节点代码示例

Stat stat = zooKeeper.setData("/testnode", "Higgin".getBytes(), );
System.out.println("修改后数据的版本号为---"+stat.getVersion());

【运行结果】

先看下对应的数据版本号信息

看下控制台运行结果

修改下代码,将版本号改为0,与zk上要修改的数据的版本号保持一致

Stat stat = zooKeeper.setData("/testnode", "Higgin".getBytes(), );
System.out.println("修改后数据的版本号为---"+stat.getVersion());

【查看运行结果】

【删除节点】

/**
* 删除节点
* 注意:version版本号必须和要删除的节点数据的版本号一致
*/
public void delete(String path, int version)

【删除实例】

zooKeeper.delete("/testnode",);

【运行结果】

删除前,先看下对应节点数据

执行删除代码后,可以看到节点已经不存在了

【获取节点数据】

public byte[] getData(String path, boolean watch, Stat stat)
public byte[] getData(String path, Watcher watcher, Stat stat)
public void getData(String path, Watcher watcher, DataCallback cb, Object ctx)
public void getData(String path, boolean watch, DataCallback cb, Object ctx)

[获取节点数据实例]

byte[] dateBytes = zooKeeper.getData("/testnode", true, null);
String str = new String(dateBytes);
System.err.println("获取的数据为==="+str);

[运行结果]

【获取子节点的列表数据】

public List<String> getChildren(String path, Watcher watcher)
public List<String> getChildren(String path, boolean watch, Stat stat)
public List<String> getChildren(String path, boolean watch, Stat stat)
public void getChildren(String path, Watcher watcher, ChildrenCallback cb, Object ctx)
......

[获取子节点列表实例]

List<String> childList = zooKeeper.getChildren("/testnode", null);
for (String child : childList) {
System.err.println("子节点=="+child);
}

[ 运行结果 ]

先看下zk上对应的数据

[ 控制台运行结果 ]

06_zookeeper原生Java API使用的更多相关文章

  1. mybatis Java API

    既然你已经知道如何配置 MyBatis 和创建映射文件,你就已经准备好来提升技能了. MyBatis 的 Java API 就是你收获你所做的努力的地方.正如你即将看到的,和 JDBC 相比, MyB ...

  2. Java数据持久层框架 MyBatis之API学习八(Java API详解)

    对于MyBatis的学习而言,最好去MyBatis的官方文档:http://www.mybatis.org/mybatis-3/zh/index.html 对于语言的学习而言,马上上手去编程,多多练习 ...

  3. SpringMVC系列(五)使用 Serlvet 原生的 API 作为目标方法的参数

    SpringMVC的Handler方法可以接受哪些 ServletAPI 类型的参数 • HttpServletRequest• HttpServletResponse• HttpSession• j ...

  4. MyBatis——Java API

    Java API 既然你已经知道如何配置 MyBatis 和创建映射文件,你就已经准备好来提升技能了. MyBatis 的 Java API 就是你收获你所做的努力的地方.正如你即将看到的,和 JDB ...

  5. 已看1.熟练的使用Java语言进行面向对象程序设计,有良好的编程习惯,熟悉常用的Java API,包括集合框架、多线程(并发编程)、I/O(NIO)、Socket、JDBC、XML、反射等。[泛型]\

    1.熟练的使用Java语言进行面向对象程序设计,有良好的编程习惯,熟悉常用的Java API,包括集合框架.多线程(并发编程).I/O(NIO).Socket.JDBC.XML.反射等.[泛型]\1* ...

  6. Java API操作ZooKeeper

    创建会话 package org.zln.zk; import org.apache.zookeeper.WatchedEvent; import org.apache.zookeeper.Watch ...

  7. Mybatis学习--Java API

    学习笔记,选自Mybatis官方中文文档:http://www.mybatis.org/mybatis-3/zh/java-api.html#directoryStructure 既然你已经知道如何配 ...

  8. Java-MyBatis: MyBatis3 | Java API

    ylbtech-Java-MyBatis:  MyBatis3 | Java API 1.返回顶部 1. Java API 既然你已经知道如何配置 MyBatis 和创建映射文件,你就已经准备好来提升 ...

  9. SpringMvc 支持一下类型Serlvet 原生的 API 作为目标方法的参数

    /** * 可以使用 Serlvet 原生的 API 作为目标方法的参数 具体支持以下类型 * * HttpServletRequest * HttpServletResponse * HttpSes ...

随机推荐

  1. HTML5 Canvas核心技术 图形、动画与游戏开发学习总结

    save 和 restore 函数的应用 保存canvas和恢复canvas clip函数的应用 文字的绘制 背景图片的绘制 离屏canvas 基于时间的运动

  2. 2019 CCPC-Wannafly Winter Camp Day2(Div2, onsite)

    solve 4/11 A Erase Numbers II Code:KK Thinking :KK 用ans表示当前最优答案,maxx表示遍历到的最大数字,一开始ans肯定等于a[ 1 ]+a[ 2 ...

  3. 同时安装Python2和Python3,如何兼容并切换使用详解

    由于历史原因,Python有两个大的版本分支,Python2和Python3,又由于一些库只支持某个版本分支,所以需要在电脑上同时安装Python2和Python3,因此如何让两个版本的Python兼 ...

  4. 【OpenCV-Python】-图像形态学转化

    原文为段立辉翻译,感谢Linux公社此文档为自学转述,如有侵权请联系本人. 目标: • 学习不同的形态学操作,例如腐蚀,膨胀,开运算,闭运算等 • 学习的函数有:cv2.erode(),cv2.dil ...

  5. 在用 Node.js 起服务之前,我们应该知道这些

    网络分层 了解计算机网络的同学都知道 OSI 七层网络模型和 TCP/IP 模型.OSI 七层模型是理论上的网络通信模型,而 TCP/IP 是现实中的网络通信概念模型.它们之间的对比关系参考下图. 本 ...

  6. python API url 级联生成

    参考了一下公司 python 达人 rpc 接口级联 api 调用 rpc.api.users.list() rpc.api.login(username='',password='') rpc['a ...

  7. 【javascript/css】关于鼠标事件onmousexxx和css伪类hover

    在运用鼠标移入移出事件时,一般有两种做法,一种是DOM事件的"onmouseover"和"onmouseout",还有一种是css的伪类":hover ...

  8. document.documentElement和document.body 与document.compatMode的关系

    首先我们看看document.compatMode(兼容模式): document.compatMode它有两种可能的返回值:BackCompat和CSS1Compat, document.compa ...

  9. XPath语法简介

    XPath是一种在xml中查找信息的语言,具体可参考W3school XPath教程 XPath是以路径表达式来选择XML文档中的节点或节点集 === XPath节点(Node) 在 XPath 中, ...

  10. 用.net 2.0(或.net 3.5)开发的程序在.net 4.0的环境中运行的解决方案

    引用:.NET2.0程序集无法在.net 4.0 中运行的解决方案 1. 原来是在.net 2.0 (VS2008)的环境下的程序,通过升级到.net 4.0 (VS2013)导致程序运行不了 提示需 ...