zookeeper - 通过java代码连接zookeeper(2)
首先创建一个Maven项目
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <groupId>groupId</groupId>
<artifactId>code</artifactId>
<version>1.0-SNAPSHOT</version> <dependencies>
<!-- https://mvnrepository.com/artifact/com.101tec/zkclient -->
<dependency>
<groupId>com.101tec</groupId>
<artifactId>zkclient</artifactId>
<version>0.11</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.zookeeper/zookeeper -->
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.5.4-beta</version>
<type>pom</type>
</dependency> <!-- https://mvnrepository.com/artifact/junit/junit -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency> </dependencies> </project>
pom.xml
package com.amber; import org.apache.zookeeper.*;
import org.apache.zookeeper.data.Stat;
import java.io.IOException; /**
* zookeeper
* 连接zookeeper
* 创建znode
* 获取znode值
* 断开链接
*/
public class ZookeeperDemo {
private ZooKeeper zookeeper; /**
* 链接zookeeper
* @return
* @throws IOException
*/
public ZooKeeper zkConnect( ) throws IOException {
//zookeeper的ip:端口
String path = "127.0.0.1:2181";
//第二个参数是超时时间,第三个参数是设置观察者,现在可以先不管
zookeeper = new ZooKeeper(path, 20 * 1000, null);
return zookeeper;
} /**
* 创建znode节点
* @param path znode的路径
* @param value znode的值
* @param watcher
* @param node //创建node的模式
* @throws KeeperException
* @throws InterruptedException
*/
public void createZnode(String path, byte[] value, Watcher watcher, CreateMode node ) throws KeeperException, InterruptedException {
zookeeper.create(path, value, ZooDefs.Ids.OPEN_ACL_UNSAFE, node);
} /**
* 通过path获得znode的值
* @param path
* @return
* @throws KeeperException
* @throws InterruptedException
*/
public String getZnodeValue(String path ) throws KeeperException, InterruptedException {
//第二个值是代表是否开启监听,这里还是先不管.第三个参数就是结构体
byte[] data = zookeeper.getData(path, false, new Stat());
return new String(data);
} public void close() {
try {
if (zookeeper != null) {
zookeeper.close();
}
} catch (InterruptedException e) {
e.printStackTrace();
}
} public static void main(String[] args) throws IOException, KeeperException, InterruptedException {
ZookeeperDemo zookeeperDemo = new ZookeeperDemo();
//获取连接
ZooKeeper zooKeeper = zookeeperDemo.zkConnect();
//创建znode
zookeeperDemo.createZnode("/amber", "hahaha".getBytes(), null, CreateMode.PERSISTENT);
//获取znode的值
String znodeValue = zookeeperDemo.getZnodeValue("/amber");
System.out.println(znodeValue); zookeeperDemo.close(); }
}
ZookeeperDemo
通过上面的代码就可以实现通过java代码操控zookeeper.但是你可能有疑惑的是
- Create.PERSISTENT是什么
- watcher是什么
Znode的四种类型
//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by Fernflower decompiler)
// package org.apache.zookeeper; import org.apache.yetus.audience.InterfaceAudience.Public;
import org.apache.zookeeper.KeeperException.BadArgumentsException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory; @Public
public enum CreateMode {
PERSISTENT(0, false, false),
PERSISTENT_SEQUENTIAL(2, false, true),
EPHEMERAL(1, true, false),
EPHEMERAL_SEQUENTIAL(3, true, true); private static final Logger LOG = LoggerFactory.getLogger(CreateMode.class);
private boolean ephemeral;
private boolean sequential;
private int flag; private CreateMode(int flag, boolean ephemeral, boolean sequential) {
this.flag = flag;
this.ephemeral = ephemeral;
this.sequential = sequential;
} public boolean isEphemeral() {
return this.ephemeral;
} public boolean isSequential() {
return this.sequential;
} public int toFlag() {
return this.flag;
} public static CreateMode fromFlag(int flag) throws KeeperException {
switch(flag) {
case 0:
return PERSISTENT;
case 1:
return EPHEMERAL;
case 2:
return PERSISTENT_SEQUENTIAL;
case 3:
return EPHEMERAL_SEQUENTIAL;
default:
String errMsg = "Received an invalid flag value: " + flag + " to convert to a CreateMode";
LOG.error(errMsg);
throw new BadArgumentsException(errMsg);
}
}
}
CreateMode
znode分四种类型
PERSISTENT 持久节点 对应命令 create path valuePERSISTENT_SEQUENTIAL 顺序自动编号持久化节点,这种节点会根据当前已存在的节点数自动加 1 (有序持久节点)create -s path valueEPHEMERAL 临时节点, 客户端session超时这类节点就会被自动删除 create -e path valueEPHEMERAL_SEQUENTIAL 临时自动编号节点 (临时有序节点) create -s -e path valueCreateMode是一个枚举类型,里面有四个对象分别是.表示的就是Znode的类型
PERSISTENT(0, false, false), //持久节点
PERSISTENT_SEQUENTIAL(2, false, true), //有序节点
EPHEMERAL(1, true, false), //临时节点 只存在本次session中,当服务器重启后就会不见
EPHEMERAL_SEQUENTIAL(3, true, true); //有序临时节点 重启后数据不见
在创建持久节点(PERSISTENT)的时候,应该注意因为znode的path是不允许重复的,因此在创建持久节点之前,应先判断节点是否存在。但是持久有序节点(PERSISTENT_SEQUENTIAL)会自动在/path后面跟上dataVersion序号
if (zooKeeper.exists(path, false) == null) {
zookeeperWatchDemo.createZnode(path, value.getBytes(), null, CreateMode.PERSISTENT);
}
watcher
Zookeeper支持发布订阅功能,引入了watcher机制进行监听。当数据进行变动以后,可以及时通知客户端,数据进行了变动,并且把相应的时间通知给Watcher的Client。
watcher的特性:
- Watcher一次性触发器:只能监听一次,是一个一次性的动作,如果需要监听多次,那么应该递归
- 可以使用系统默认的watcher,也可以自定义Watcher.自定义Watcher必须实现
org.apache.zookeeper.Watcher接口
- Zookeeper的getData(),getChildren(),exists()都可以设置Watch选项。当watch为false的时候,或者watcher为null的时候代表不开启watch
new Watcher() {
@Override
public void process(WatchedEvent watchedEvent) {
triggerWatch(path);
}
package com.amber; import org.apache.zookeeper.*;
import org.apache.zookeeper.data.Stat; import java.io.IOException; public class ZookeeperWatchDemo {
private ZooKeeper zookeeper;
private String oldValue = "";
private String newValue = "";
public ZooKeeper zkConnect( ) throws IOException {
String path = "127.0.0.1:2181";
zookeeper = new ZooKeeper(path, 20 * 1000, null);
return zookeeper;
} public void createZnode(String path, byte[] value, Watcher watcher, CreateMode node ) throws KeeperException, InterruptedException {
zookeeper.create(path, value, ZooDefs.Ids.OPEN_ACL_UNSAFE, node);
} public String getZnodeValue(final String path ) throws KeeperException, InterruptedException {
byte[] data = zookeeper.getData(path, new Watcher() {
@Override
public void process(WatchedEvent watchedEvent) {
triggerWatch(path);
}
}, new Stat());
oldValue = new String(data);
return new String(data);
} public boolean triggerWatch (String path) {
byte[] data = new byte[0];
try {
data = zookeeper.getData(path, new Watcher() {
@Override
public void process(WatchedEvent watchedEvent) {
triggerWatch(path);
}
}, new Stat());
} catch (KeeperException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
newValue = new String(data);
if (oldValue.equals(newValue)) {
System.out.println("on change");
return false;
} else {
System.out.println("oldvalue: " + oldValue + "new value: " + newValue);
oldValue = newValue;
return true;
}
} public static void main(String[] args) throws IOException, KeeperException, InterruptedException {
//创建
ZookeeperWatchDemo zookeeperWatchDemo = new ZookeeperWatchDemo();
ZooKeeper zooKeeper = zookeeperWatchDemo.zkConnect();
String path = "/amberas";
String value = "hahahahaha";
if (zooKeeper.exists(path, false) == null) {
zookeeperWatchDemo.createZnode(path, value.getBytes(), null, CreateMode.PERSISTENT);
} String znodeValue = zookeeperWatchDemo.getZnodeValue(path);
System.out.println(znodeValue); Thread.sleep(1000 * 60 * 50);
}
}
ZookeeperWatchDemo
zookeeper - 通过java代码连接zookeeper(2)的更多相关文章
- Java代码操作zookeeper
.personSunflowerP { background: rgba(51, 153, 0, 0.66); border-bottom: 1px solid rgba(0, 102, 0, 1); ...
- mongodb3.0分片及java代码连接操作测试(开启用户验证)
最近抽时间搭建了一下mongodb简单的分片,整个过程还算是蛮顺利,只不过在用户验证这一块遇到了一些问题,好在最后终于搞定. 一.服务器搭建过程: 1.安装四个mongodb:一个作为config.一 ...
- zookeeper java api(使用java代码操作zookeeper)
1 导入相关的pom依赖 <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId&g ...
- java代码连接本地redis数据库
关于redis的介绍在这里就不说了.今天主要讲解,如何连接redis.连接之前.必须要做的几点: 一.安装redis.下载服务和客户端,然后 二.启动redis服务. 经过这两步的测通以后.我们只需要 ...
- java代码连接oracle数据库的方法
oracle连接数据库的方式和mysql是大同小异的,主要的困难点在于oracle的数据库驱动包和依赖只有官方提供,如果你是用maven添加依赖的话,需要自己从官网下载jar包安装到你本地的maven ...
- Zookeeper的java客户端API使用方法(五)
前面几篇博文,我们简单的介绍了一下zookeeper,如何安装zookeeper集群,以及如何使用命令行等.这篇博文我们重点来看下Zookeeper的java客户端API使用方式. 创建会话 客户端可 ...
- 12. ZooKeeper之Java客户端API使用—创建会话。
转自:https://blog.csdn.net/en_joker/article/details/78686649 客户端可以通过创建一个ZooKeeper(org.apache.zookeeper ...
- 不使用spring的情况下原生java代码两种方式操作mongodb数据库
由于更改了mongodb3.0数据库的密码,导致这几天storm组对数据进行处理的时候,一直在报mongodb数据库连接不上的异常. 主要原因实际上是和mongodb本身无关的,因为他们改的是配置 ...
- 使用非java代码编程
使用非JAVA代码 JAVA语言及其标准API(应用程序编程接口)应付应用程序的编写已绰绰有余.但在某些情况下,还是必须使用非JAVA编码.例如,我们有时要访问操作系统的专用特性,与特殊的硬件 ...
随机推荐
- svn新建文件不能提交的解决方法
svn新建文件不能提交的解决方法 在当前新建文件的目录下,右键空白处: 选择Properties 找到所有有ignore字眼的属性,查看这个属性的继承目录(inherited from),入我的是cl ...
- Ubuntu18.04 显卡驱动+Cuda安装踩坑记录 以及Ubuntu虚拟内存的添加
前几天买了张亮机卡,终于把主显卡成功直连到Unraid OS的虚拟机上了.然后就开始安装ubuntu系统开始配置环境,遇到了不少坑,特此记录. gcc版本问题 在安装显卡驱动的时候,不要修改gcc版本 ...
- 命名对象继承1-验证Create*命名对象安全属性的传递
windows核心编程 第5版 48页 下半部写道 进程B调用CreateMutex时,它会向函数传递安全属性信息和第二参数.如果已经存在一个指定名称的对象,这些对象就会被忽略 于是我通过代码来验证这 ...
- useradd、id、userdel、usermod、chsh、passwd、pwck
1.useradd [-cdefgGmkMsu] 用户名称 用来添加用户 -c “备注“:加上备注文字 -d 路径:指定家目录 -e 有效期限:指定帐号的有效期限: -f 缓冲天数:指定在密码过期后多 ...
- 整理基础的CentOS常用命令
如何知道apache装在哪里? which httpd 1.查看系统使用端口并释放端口 [root@my_nn_01 WEB-INF]# lsof -w -n -i tcp:80 COMMAND ...
- 夯实Java基础系列16:一文读懂Java IO流和常见面试题
本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial 喜欢的话麻烦点下 ...
- tiki-graph_formula.php代码执行漏洞复现(或许??)
1.不知道从哪里翻出来的虚拟机镜像(不知道甚么时候出现在磁盘里面的) 打开配置一下是tikiwiki这个东西 2.遇到陌生的玩意总是忍不住好奇心的,打开nikto扫描一下,发现有些奇怪的东西 本来没抱 ...
- Mongoose: aggregate聚合 $group使用说明
aggregate聚合是通过管道操作实现的.聚合管道里的每一步输出,都会作为下一步的输入,每一步在输入文档执行完操作后生成输出文档. 聚合管道: $project 修改输入文档的结构.可以用来重命名 ...
- 【Java】访问mysql数据库视图
数据库连接Connect: package cn.hkwl.zaxq.mysql; import java.sql.Connection; import java.sql.DriverManager; ...
- 小程序webview跳转页面后没有返回按钮完美解决方案
随着小程序越来越火爆,使一个产品如果只有公众号H5页面和APP显得不怎么完美,总感觉不搭上小程序这趟流量车,就会少了点什么,心里别扭地很.在此驱动下,我所在公司也决定赶紧上车. 但是,如果要按照小程序 ...