Zookeeper java api
Zookeeper java api 主要有以下几个:
| 方法名称 | 描述 |
|---|---|
| String create(final String path, byte data[], List acl, CreateMode createMode) |
创建一个znode节点, 参数: 路径、 znode内容,ACL(访问控制列表)、 znode创建类型 |
| void delete(final String path, int version) |
删除一个znode节点, 参数: 路径、版本号;如果版本号与znode的版本号不一致,将无法删除,是一种乐观加锁机制;如果将版本号设置为-1,不会去检测版本,直接删除; |
| Stat exists(final String path, Watcher watcher) |
判断某个znode节点是否存在 参数: 路径、Watcher(监视器);当这个znode节点被改变时,将会触发当前Watcher |
| Stat exists(String path, boolean watch) |
判断某个znode节点是否存在 参数: 路径、并设置是否监控这个目录节点,这里的 watcher 是在创建 ZooKeeper 实例时指定的 watcher |
| Stat setData(final String path, byte data[], int version) |
设置某个znode上的数据 参数: 路径、数据、版本号;如果为-1,跳过版本检查 |
| byte[] getData(final String path, Watcher watcher, Stat stat) |
获取某个znode上的数据 参数: 路径、监视器、数据版本等信息 |
| List getChildren(final String path, Watcher watcher) |
获取某个节点下的所有子节点 参数: 路径、监视器;该方法有多个重载 |
package com.test.protobuf; import org.apache.zookeeper.*; import java.io.IOException;
import java.util.concurrent.CountDownLatch; /**
* Created by szekinwin on 2017/7/7.
*/
public class ZookeeperDemo { //zookeeper连接地址
private static final String CONNECT_ADDR="172.31.19.222:2181,172.31.19.223:2181,172.31.19.234:2181";
//超时时间
private static final int SESSION_TIMEOUT=2000;
//等待zookeeper连接成功,程序继续往下执行(zookeeper连接是异步连接)
private static final CountDownLatch countDownLatch = new CountDownLatch(1); public static void main (String [] args){
try {
ZooKeeper zooKeeper = new ZooKeeper(CONNECT_ADDR, SESSION_TIMEOUT, new Watcher() {
public void process(WatchedEvent event) {
Event.KeeperState state = event.getState();
Event.EventType type = event.getType();
if(Event.KeeperState.SyncConnected==state){
if(Event.EventType.None==type){
countDownLatch.countDown();
System.out.println("Zookeeper connect successfully!");
}
}
}
});
try {
countDownLatch.await();
try {
//创建节点 节点类型为PERSISTENT 永久型 EPHEMERAL临时节点,客户端session超时这类节点就会被自动删除
zooKeeper.create("/testRoot","testRoot".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
//创建子节点 zookeeper java api 不支持递归创建节点
zooKeeper.create("/testRoot/children","children".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
//获取节点值
byte [] msg=zooKeeper.getData("/testRoot/children",false,null);
System.out.println(new String(msg));
//修改节点值
zooKeeper.setData("/testRoot/children","testRoot Children".getBytes(),-1);
byte [] msg2=zooKeeper.getData("/testRoot/children",false,null);
System.out.println(new String(msg2));
//判断节点是否存在
System.out.println(zooKeeper.exists("/testRoot/children",false));
//删除节点
zooKeeper.delete("/testRoot/children",-1);
zooKeeper.close();
} catch (KeeperException e) {
e.printStackTrace();
}
} catch (InterruptedException e) {
e.printStackTrace();
}
} catch (IOException e) {
e.printStackTrace();
}
} }
Zookeeper java api的更多相关文章
- 9. 使用ZooKeeper Java API编程
ZooKeeper是用Java开发的,3.4.6版本的Java API文档可以在http://zookeeper.apache.org/doc/r3.4.6/api/index.html上找到. Ti ...
- 14.ZooKeeper Java API 使用样例
转自:http://www.aboutyun.com/thread-7332-1-1.html package com.taobao.taokeeper.research.sample; import ...
- zookeeper Java API 简单操作示例
本文主要介绍如何在java IDE中如何应用使用客户端与zookeeper服务器通信. 首先搭建maven环境,并在pom文件中加入zookeeper引用包: <!-- https://mvnr ...
- Zookeeper JAVA API的使用
0. 前言 zookeeper安装及使用 http://www.cnblogs.com/rocky-fang/p/7880309.html 1. 开发环境配置 1.1 idea创建一个maven工程 ...
- zookeeper JAVA API 简单操作
package org.admln.program.Zoo_Test; import java.io.IOException; import java.security.NoSuchAlgorithm ...
- Zookeeper Java API调用
引入zookeeper-3.4.11.jar public class ZooKeeperTest implements Watcher{ //public final static String z ...
- zookeeper java api(使用java代码操作zookeeper)
1 导入相关的pom依赖 <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId&g ...
- Zookeeper Curator API 使用
0. 原生 ZOOKEEPER JAVA API http://www.cnblogs.com/rocky-fang/p/9030438.html 1. 概述 Curator采用cache封装对事件 ...
- ZooKeeper Java例子(六)
A Simple Watch Client 为了向你介绍ZooKeeper Java API,我们开发了一个非常简单的监视器客户端.ZooKeeper客户端监视一个ZooKeeper节点的改变并且通过 ...
随机推荐
- 解决从Windows拷贝来的文件到Ubuntu出现乱码的问题
1.转换文件内容编码 Windows下天生的纯文本文件,其中文编码为GBK,在Ubuntu下显示为乱码,可以使用iconv命令进行转换: iconv -f gbk -t utf8 sour ...
- spring常见注解说明
1. @ActiveProfiles("test") 我理解这个注解的主要用途是区分不同的环境.一般公司开发一个项目时,会区分测试环境.生产环境等.添加该注解,说明读取的profi ...
- vim的快捷键
vim的快捷键 (〇)3中模式之间的切换 默认在命令模式. i键,从命令模式,进入插入模式. 冒号(:)键,从命令模式,进入末行模式. Esc键,从插入模式.末行模式,进入命令模式. (一)命令模式下 ...
- python web框架 django wsgi 理论
django wsgi python有个自带的wsgi模块 可以写自定义web框架 用wsgi在内部创建socket对象就可以了 自己只写处理函数就可以了django只是web框架 他也不负责写soc ...
- C#版-Redis缓存服务器在Windows下的使用
Redis缓存服务器是一款key/value数据库,读110000次/s,写81000次/s,因为是内存操作所以速度飞快,常见用法是存用户token.短信验证码等 官网显示Redis本身并没有Wind ...
- 浅谈Spark2.x中的Structured Streaming
在Spark2.x中,Spark Streaming获得了比较全面的升级,称为Structured Streaming,和之前的很不同,功能更强大,效率更高,跟其他的组件整合性也更好. 连续应用程序c ...
- UVA10905: Children's Game(排序)
题目:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=68990#problem/A 题目需求:,给n个数字,将它们重新排序得到一个最大的数 ...
- C++ error C2064:
error C2064: term does not evaluate to a function 错误原因,非函数,当成函数使用了
- 从硬件到语言,详解C++的内存对齐(memory alignment)
转载请保留以下声明 作者:赵宗晟 出处:https://www.cnblogs.com/zhao-zongsheng/p/9099603.html 很多写C/C++的人都知道“内存对齐”的概念以及规则 ...
- org.apache.ibatis.binding.BindingException: Mapper method 'attempted to return null from a method with a primitive return type (long).
一.问题描述 今天发现测试环境报出来一个数据库相关的错误 org.apache.ibatis.binding.BindingException: Mapper method 'attempted to ...