Java API操作ZooKeeper
- 创建会话
package org.zln.zk; import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZooKeeper; import java.io.IOException; /**
* Created by sherry on 16/8/27.
*/
public class TestZooKeeperClientApi { private static ZooKeeper zooKeeper; public static void main(String[] args) throws IOException, InterruptedException {
createSession();
} /**
* 创建会话
*/
private static ZooKeeper createSession() throws IOException, InterruptedException {
//实例化的过程,同时也是与ZooKeeper建立连接的过程,参数说明:ip:port 超时时间 监听器(实现water接口,监听器用于接收通知)
zooKeeper = new ZooKeeper("127.0.0.1:2181", 5000, new Watcher() {
@Override
public void process(WatchedEvent watchedEvent) {
System.out.println("收到事件:"+watchedEvent);//收到事件:WatchedEvent state:SyncConnected type:None path:null //TODO
}
});
System.out.println("查看状态:"+zooKeeper.getState());//查看状态:CONNECTING //如果不停一段时间,那么,监听器还没收到监听,方法就已经退出了
Thread.sleep(5000); return zooKeeper; }
}
创建会话
- 创建节点
package org.zln.zk; import org.apache.zookeeper.*;
import org.apache.zookeeper.data.ACL;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.ArrayList; /**
* Created by sherry on 16/8/27.
*/
public class TestZooKeeperClientApi { private static Logger logger = LoggerFactory.getLogger(TestZooKeeperClientApi.class); private static ZooKeeper zooKeeper; public static void main(String[] args) throws IOException, InterruptedException {
createSession();
} /**
* 创建会话
*/
private static ZooKeeper createSession() throws IOException, InterruptedException {
//实例化的过程,同时也是与ZooKeeper建立连接的过程,参数说明:ip:port 超时时间 监听器(实现water接口,监听器用于接收通知)
zooKeeper = new ZooKeeper("127.0.0.1:2181", 5000, new Watcher() {
@Override
public void process(WatchedEvent watchedEvent) {
//TODO 与 ZooKeeper 的交互,一般都放在这里
if (watchedEvent.getState() == Event.KeeperState.SyncConnected){//已连接
logger.info("连接上了"); try {
//参数说明:节点路径 数据的字节数组 权限 创建节点模式
String nodePath = createNode(zooKeeper,"/node_1","123".getBytes("UTF-8"), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
logger.info("创建节点:"+nodePath);
} catch (UnsupportedEncodingException|KeeperException|InterruptedException e) {
e.printStackTrace();
} }
}
});
logger.info("查看状态:"+zooKeeper.getState());//查看状态:CONNECTING //如果不停一段时间,那么,监听器还没收到监听,方法就已经退出了
Thread.sleep(5000); return zooKeeper; } /**
* 创建ZooKeeper节点
* @param zooKeeper ZooKeeper连接
* @return 节点路径
*/
public static String createNode(ZooKeeper zooKeeper, String path, byte[] bytes, ArrayList<ACL> acls,CreateMode createMode) throws UnsupportedEncodingException, KeeperException, InterruptedException {
//参数说明:节点路径 数据的字节数组 权限 创建节点模式
return zooKeeper.create(path,bytes, acls, createMode);
}
}
创建节点
创建模式
PERSISTENT 持久节点
PERSISTENT_SEQUENTIAL 持久顺序节点
EPHEMERAL 临时节点
EPHEMERAL_SEQUENTIAL 临时顺序节点
以上代码,是属于同步创建
/**
* 异步创建节点
* @param zooKeeper
* @param path
* @param bytes
* @param acls
* @param createMode
* @throws KeeperException
* @throws InterruptedException
*/
public static void asCreateNode(ZooKeeper zooKeeper, String path, byte[] bytes, ArrayList<ACL> acls,CreateMode createMode) throws KeeperException, InterruptedException { //异步创建需要增加 AsyncCallback.StringCallback 接口的实现类 以及 一个上下文对象参数
zooKeeper.create(path, bytes, acls, createMode, new AsyncCallback.StringCallback() {
/**
*
* @param rc 节点创建结果返回码 0-节点创建成功
* @param path 节点真实路径
* @param ctx 异步调用上下文 就是 create方法本地调用的那个最后一个参数
* @param name
*/
@Override
public void processResult(int rc, String path, Object ctx, String name) {
StringBuilder stringBuilder = new StringBuilder();
stringBuilder.append("\nrc="+rc+"\n" +
"path="+path+"\n" +
"ctx="+ctx+"\n" +
"name="+name+"\n");
logger.info(stringBuilder.toString());
}
},"异步创建");
}
异步方式创建节点
- 获取子节点
/**
* 同步方式获取子节点
* @param zooKeeper 连接
* @param parentPath 父路径
* @return
* @throws KeeperException
* @throws InterruptedException
*/
public static List<String> getChildList(ZooKeeper zooKeeper,String parentPath) throws KeeperException, InterruptedException {
//参数说明: 父节点路径 是否需要关注子节点的变化
List<String> childs = zooKeeper.getChildren(parentPath,false);
return childs;
}
同步方式获取子节点且不关注子节点的变化
/**
* 异步方式获取子节点 关注子节点变化
* @param zooKeeper 连接
* @param parentPath 父路径
*/
public static void asGetChildListAndWatch(ZooKeeper zooKeeper,String parentPath){
zooKeeper.getChildren(parentPath, true, new AsyncCallback.Children2Callback() {
@Override
public void processResult(int rc, String path, Object ctx, List<String> children, Stat stat) {
logger.info("变化后的子节点:");
for (String name:children){
logger.info("子节点:"+name);
}
}
},"关注子节点变化");
}
AsyncCallback.Children2Callback接口实现异步关注
目前为止可以发现这个规律,有回调函数的是异步方式调用,没有回调函数的是同步调用
问:同步调用和异步调用的使用场景是???
答:下面的操作依赖调用结果的时候,就需要调用同步方法
package org.zln.zk; import org.apache.zookeeper.*;
import org.apache.zookeeper.data.ACL;
import org.apache.zookeeper.data.Stat;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.ArrayList;
import java.util.List; /**
* Created by sherry on 16/8/27.
*/
public class TestZooKeeperClientApi { private static Logger logger = LoggerFactory.getLogger(TestZooKeeperClientApi.class); private static ZooKeeper zooKeeper; public static void main(String[] args) throws IOException, InterruptedException {
createSession(); Thread.sleep(Integer.MAX_VALUE);
} /**
* 创建会话
*/
private static ZooKeeper createSession() throws IOException, InterruptedException {
//实例化的过程,同时也是与ZooKeeper建立连接的过程,参数说明:ip:port 超时时间 监听器(实现water接口,监听器用于接收通知)
zooKeeper = new ZooKeeper("127.0.0.1:2181", 5000, new Watcher() {
@Override
public void process(WatchedEvent watchedEvent) {
//TODO 与 ZooKeeper 的交互,一般都放在这里
if (watchedEvent.getState() == Event.KeeperState.SyncConnected){//已连接
logger.info("连接上了");
try {
//同步方式创建节点
//String nodePath = sysCreateNode(zooKeeper,"/node_1","123".getBytes("UTF-8"), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
//logger.info("创建节点:"+nodePath); //异步方式创建节点
//asCreateNode(zooKeeper,"/node_2","234".getBytes("UTF-8"), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT); //同步方式获取子节点 不关注子节点变化
// List<String> list = getChildListNoWatch(zooKeeper,"/");
// for (String name:list){
// logger.info("子节点:"+name);
// } //异步方式获取节点 关注子节点变化
// asGetChildListAndWatch(zooKeeper,"/"); //同步方式获取节点数据 sysGetNodeData byte[] bytes = sysGetNodeDataNoWatch(zooKeeper,"/node_1");
logger.info("获取节点数据"+new String(bytes,"UTF-8")); deleteNode(zooKeeper,"/node_1",0);
} catch (KeeperException|InterruptedException|UnsupportedEncodingException e) {
e.printStackTrace();
} }
}
});
logger.info("查看状态:"+zooKeeper.getState());//查看状态:CONNECTING return zooKeeper; } /**
* 同步创建节点
* @param zooKeeper 连接
* @param path 节点路径
* @param bytes 字节数组数据
* @param acls 权限
* @param createMode 创建模式
* @return
* @throws UnsupportedEncodingException
* @throws KeeperException
* @throws InterruptedException
*/
public static String sysCreateNode(ZooKeeper zooKeeper, String path, byte[] bytes, ArrayList<ACL> acls,CreateMode createMode) throws UnsupportedEncodingException, KeeperException, InterruptedException {
return zooKeeper.create(path,bytes, acls, createMode);
} /**
* 异步创建节点
* @param zooKeeper 连接
* @param path 节点路径
* @param bytes 字节数组数据
* @param acls 权限
* @param createMode 创建模式
* @throws KeeperException
* @throws InterruptedException
*/
public static void asCreateNode(ZooKeeper zooKeeper, String path, byte[] bytes, ArrayList<ACL> acls,CreateMode createMode) throws KeeperException, InterruptedException { //异步创建需要增加 AsyncCallback.StringCallback 接口的实现类 以及 一个上下文对象参数
zooKeeper.create(path, bytes, acls, createMode, new AsyncCallback.StringCallback() {
/**
*
* @param rc 节点创建结果返回码 0-节点创建成功
* @param path 节点真实路径
* @param ctx 异步调用上下文 就是 create方法本地调用的那个最后一个参数
* @param name
*/
@Override
public void processResult(int rc, String path, Object ctx, String name) {
StringBuilder stringBuilder = new StringBuilder();
stringBuilder.append("\nrc="+rc+"\n" +
"path="+path+"\n" +
"ctx="+ctx+"\n" +
"name="+name+"\n");
logger.info(stringBuilder.toString());
}
},"异步创建");
} /**
* 同步方式获取子节点 不关注子节点变化
* @param zooKeeper 连接
* @param parentPath 父路径
* @return
* @throws KeeperException
* @throws InterruptedException
*/
public static List<String> sysGetChildListNoWatch(ZooKeeper zooKeeper,String parentPath) throws KeeperException, InterruptedException {
//参数说明: 父节点路径 是否需要关注子节点的变化 如果 true,则子节点发生变化后,会产生 NodeChildrenChanged 事件
List<String> childs = zooKeeper.getChildren(parentPath,false);
return childs;
} /**
* 异步方式获取子节点 关注子节点变化
* @param zooKeeper 连接
* @param parentPath 父路径
*/
public static void asGetChildListAndWatch(ZooKeeper zooKeeper,String parentPath){
zooKeeper.getChildren(parentPath, true, new AsyncCallback.Children2Callback() {
@Override
public void processResult(int rc, String path, Object ctx, List<String> children, Stat stat) {
logger.info("变化后的子节点:");
for (String name:children){
logger.info("子节点:"+name);
}
}
},"关注子节点变化");
} /**
* 同步方式获取数据
* @param zooKeeper
* @param path
* @return
* @throws KeeperException
* @throws InterruptedException
*/
public static byte[] sysGetNodeDataNoWatch(ZooKeeper zooKeeper,String path) throws KeeperException, InterruptedException {
//路径 是否关注数据变化 状态
return zooKeeper.getData(path,false,new Stat());
} /**
* 删除节点
* @param zooKeeper
* @param nodePath
* @param version
* @throws KeeperException
* @throws InterruptedException
*/
public static void deleteNode(ZooKeeper zooKeeper,String nodePath,int version) throws KeeperException, InterruptedException {
zooKeeper.delete(nodePath,version);
} }
客户端代码汇总
除了ZooKeeper提供的Java API外,还有两种客户端,ZKClient和Curator两种客户端,都是对原生API的封装,使得操作更方便
《从PAXOS到ZOOKEEPER分布式一致性原理与实践》,可以参考这本书
Java API操作ZooKeeper的更多相关文章
- 六、Java API操作zookeeper节点
目录 前文 pom.xml文件增加依赖 新建java文件:ZookeeperTest GitHub文件下载 前文 一.CentOS7 hadoop3.3.1安装(单机分布式.伪分布式.分布式 二.JA ...
- Java API 操作Zookeeper
一.依赖 <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId>zookee ...
- zookeeper的java api操作
zookeeper的java api操作 创建会话: Zookeeper(String connectString,int sessionTimeout,Watcher watcher) Zookee ...
- Java curator操作zookeeper获取kafka
Java curator操作zookeeper获取kafka Curator是Netflix公司开源的一个Zookeeper客户端,与Zookeeper提供的原生客户端相比,Curator的抽象层次更 ...
- hadoop2-HBase的Java API操作
Hbase提供了丰富的Java API,以及线程池操作,下面我用线程池来展示一下使用Java API操作Hbase. 项目结构如下: 我使用的Hbase的版本是 hbase-0.98.9-hadoop ...
- java api操作
java api操作 导入开发包 将hbase安装包中lib下包导入java项目 创建表 Configuration conf = HBaseConfiguration.create(); c ...
- hive-通过Java API操作
通过Java API操作hive,算是测试hive第三种对外接口 测试hive 服务启动 package org.admln.hive; import java.sql.SQLException; i ...
- 使用Java API操作HDFS文件系统
使用Junit封装HFDS import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.fs.*; import org ...
- Kafka系列三 java API操作
使用java API操作kafka 1.pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xs ...
随机推荐
- linux系统中 redis 保存数据的5种形式 linux后端模式启动 jedis无法通过IP地址和端口号访问如何修改linux防火墙
vim修改redis.conf配置文件(我的已经复制到虚拟机的/usr/local/redis/bin目录下)为daemonize yes, 以后端模式启动 ./redis-server redis. ...
- Chrome 调试工具的一些高阶功能
Chrome 内置抓包工具 Block requests 截取长图 代码的覆盖率分析 Make site better Chrome 内置抓包工具 在浏览器地址栏输入chrome://net-inte ...
- mysql基础 日期类型
- Spring MVC 接收前端参数的方式
方式一: 普通方式接收 1 @RequestMapping("/index") 2 public String getUserName(String username) { 3 S ...
- webmin纯web界面管理linux系统
关键字: 摘要:从Windows环境的管理转到Linux环境的管理时所面临的挑战之一是,您需要去学习利用新的工具.作为一个管理员,您希望理解操作系统的细节以发挥它的最大功效.但是,当您还处在学习阶段时 ...
- 11.VUE学习之提交表单时拿到input里的值
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http ...
- Flask初学者:蓝图Blueprint
蓝图这个名字好像就是根据单词Blueprint字面意思来,跟平常我们理解的蓝图完全挂不上钩,这里蓝图就是指Blueprint. 使用蓝图的好处是可以将不同功能作用的视图函数/类视图放到不同的模块中,可 ...
- Android 数据库中的数据给到ListView
前言:因为之前学的都是用一个自己定义的类,完成将某一个bean中的数据直接获取,而实际中通常是通过数据库来得到的,总之,最终就是要得到数据.提一下最重要的东西,我把它叫做代理,如同一个校园代理,没有他 ...
- 3714: [PA2014]Kuglarz
3714: [PA2014]Kuglarz 链接 思路: 好题.对于每个点都需要确定它的值,那么一个点可以直接询问[i,i]来确定,或者已经知道了[i,j]和[i+1,j]推出来. 但是可能产生冲突, ...
- P2985 [USACO10FEB]吃巧克力Chocolate Eating
P2985 [USACO10FEB]吃巧克力Chocolate Eating 题目描述 Bessie has received N (1 <= N <= 50,000) chocolate ...