Zookeeper(3)---java客户端的使用
前面介绍了zk指令的使用,这里说一下java客户端中怎么使用这些指令
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.5.5</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
客户端创建参数:
1.初始化连接:org.apache.zookeeper.ZooKeeper,实例化该类之后将会自动与ZK建立连接。构造参数说明如下:
|
参数名称 |
类型 |
说明 |
|
connectString |
String |
连接串,包括ip+端口 ,集群模式下用逗号隔开 192.168.0.101:2181,192.168.0.67:2181 |
|
sessionTimeout |
int |
会话超时时间,该值不能超过服务端所设置的 minSessionTimeout 和maxSessionTimeout |
|
watcher |
Watcher |
会话监听器,服务端事件将会触该监听 |
|
sessionId |
long |
自定义会话ID |
|
sessionPasswd |
byte[] |
会话密码 |
|
canBeReadOnly |
boolean |
该连接是否为只读的 |
|
hostProvider |
HostProvider |
服务端地址提供者,指示客户端如何选择某个服务来调用,默认采用StaticHostProvider实现 |
2. org.apache.zookeeper.ZooKeeper#create() 创建节点 创建节点的时候需要注意设置ACL权限,五个权限位:
int READ = 1 << 0;
int WRITE = 1 << 1;
int CREATE = 1 << 2;
int DELETE = 1 << 3;
int ADMIN = 1 << 4;
int ALL = READ | WRITE | CREATE | DELETE | ADMIN;
3.org.apache.zookeeper.ZooKeeper#getData() 查看节点数据/添加数据变化监听
4.org.apache.zookeeper.ZooKeeper#getChildren() 查看子节点/添加子节点变化监听
代码demo:
package com.nijunyang.zookeeper.demo; import org.apache.zookeeper.*;
import org.apache.zookeeper.data.ACL;
import org.apache.zookeeper.data.Id;
import org.apache.zookeeper.data.Stat;
import org.junit.Before;
import org.junit.Test; import java.io.IOException;
import java.util.ArrayList;
import java.util.List; /**
* Description:
* Created by nijunyang on 2020/10/27 21:36
*/
public class ZkClientDataChange { ZooKeeper zkClient; @Before
public void before() throws IOException {
//集群用,分割
String connectString = "192.168.0.67:2181";
zkClient = new ZooKeeper(connectString, 40000, new Watcher() {
@Override
public void process(WatchedEvent event) {
System.out.println(event.getPath());
System.out.println(event);
}
});
} //获取数据
@Test
public void getData1() throws KeeperException, InterruptedException {
byte[] data = zkClient.getData("/njy", false, null);
System.out.println(new String(data));
} //添加监听
@Test
public void getData2() throws KeeperException, InterruptedException {
//直接调用初始化的监听
byte[] data = zkClient.getData("/njy", true, null);
System.out.println(new String(data));
Thread.sleep(Integer.MAX_VALUE);
} @Test
public void getData3() throws KeeperException, InterruptedException {
//Stat 会填充带回来
Stat stat = new Stat();
//添加自定义监听
byte[] data = zkClient.getData("/njy", new Watcher() {
@Override
public void process(WatchedEvent event) {
try {
//重复添加监听
zkClient.getData(event.getPath(), this, null);
} catch (Exception e) {
e.printStackTrace();
}
System.out.println(event.getPath());
}
}, stat);
System.out.println(stat);
Thread.sleep(Long.MAX_VALUE);
} //带回调
@Test
public void getData4() throws KeeperException, InterruptedException {
zkClient.getData("/njy", false, new AsyncCallback.DataCallback() {
@Override
public void processResult(int rc, java.lang.String path, Object ctx, byte[] data, Stat stat) {
System.out.println(new String(data));
System.out.println(stat);
}
}, "");
Thread.sleep(Long.MAX_VALUE);
} //获取子节点
@Test
public void getChild() throws KeeperException, InterruptedException {
List<String> children = zkClient.getChildren("/njy", false);
children.stream().forEach(System.out::println);
} //监听子节点变化
@Test
public void getChild2() throws KeeperException, InterruptedException {
List<String> children = zkClient.getChildren("/njy", event -> {
System.out.println(event.getPath());
try {
zkClient.getChildren(event.getPath(), false);
} catch (KeeperException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
});
children.stream().forEach(System.out::println);
Thread.sleep(Long.MAX_VALUE);
} //持续监听
@Test
public void getChild3() throws KeeperException, InterruptedException {
Stat stat = new Stat();
List<String> children = zkClient.getChildren("/njy", new Watcher() {
@Override
public void process(WatchedEvent event) {
System.out.println(event.getPath());
try {
zkClient.getChildren(event.getPath(),this);
} catch (KeeperException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}, stat);
children.stream().forEach(System.out::println);
Thread.sleep(Long.MAX_VALUE);
} //创建节点
@Test
public void createNode() throws KeeperException, InterruptedException {
List<ACL> list = new ArrayList<>();
// int perm = ZooDefs.Perms.ADMIN | ZooDefs.Perms.READ;//cdwra
// int READ = 1 << 0;
// int WRITE = 1 << 1;
// int CREATE = 1 << 2;
// int DELETE = 1 << 3;
// int ADMIN = 1 << 4;
// int ALL = READ | WRITE | CREATE | DELETE | ADMIN;
int perm = ZooDefs.Perms.ALL;
//ACL权限
ACL acl = new ACL(perm, new Id("world", "anyone"));
// ACL acl2 = new ACL(perm, new Id("ip", "192.168.0.67"));
// ACL acl3 = new ACL(perm, new Id("ip", "192.168.0.101"));
list.add(acl);
// list.add(acl2);
// list.add(acl3);
zkClient.create("/njy/njyn1", "hello".getBytes(), list, CreateMode.PERSISTENT);
}
}
Zookeeper(3)---java客户端的使用的更多相关文章
- Zookeeper的java客户端API使用方法(五)
前面几篇博文,我们简单的介绍了一下zookeeper,如何安装zookeeper集群,以及如何使用命令行等.这篇博文我们重点来看下Zookeeper的java客户端API使用方式. 创建会话 客户端可 ...
- ZooKeeper学习总结(2)——ZooKeeper开源Java客户端ZkClient使用
zkclient是zookeeper的Java客户端.它让Zookeeper API 使用起来更简单:它非常方便订阅各种事件并自动重新绑定事件(会话建立.节点修改.节点删除.子节点变更等):它提供了s ...
- zookeeper的Java客户端API
zookeeper作为一个分布式服务框架,主要用来解决分布式数据一致性问题,对多种语言提供了API.这里主要记录下JAVA客户端API的使用. 1.创建会话 客户端可以通过创建一个ZooKeeper实 ...
- 02.ZooKeeper的Java客户端使用
1.ZooKeeper常用客户端比较 1.ZooKeeper常用客户端 zookeeper的常用客户端有3种,分别是:zookeeper原生的.Apache Curator.开源的zkclie ...
- Zookeeper 的 java 客户端都有哪些?
java 客户端:zk 自带的 zkclient 及 Apache 开源的 Curator.
- [转载] ZooKeeper的Java客户端API
转载自 http://www.cnblogs.com/ggjucheng/p/3370359.html http://zookeeper.apache.org/doc/trunk/javaExampl ...
- 六:ZooKeeper的java客户端api的使用
一:客户端链接测试 package com.yeepay.sxf.createConnection; import java.io.IOException; import org.apache.zoo ...
- ZooKeeper:Java客户端网络处理
了解ZooKeeper客户端的实现,对于使用ZooKeeper的客户端非常重要. 通过对客户端源码的阅读,了解了如下信息: 创建ZooKeeper对象时,应会创建一个ClientCnxn(代表了客户端 ...
- 12. ZooKeeper之Java客户端API使用—创建会话。
转自:https://blog.csdn.net/en_joker/article/details/78686649 客户端可以通过创建一个ZooKeeper(org.apache.zookeeper ...
- 13.Zookeeper的java客户端API使用方法
转自:https://blog.csdn.net/jiuqiyuliang/article/details/56012027
随机推荐
- [USACO2007FEB S] The Cow Lexicon S
题目描述 Few know that the cows have their own dictionary with W (1 ≤ W ≤ 600) words, each containing no ...
- 如何判断lib和dll是32位还是64位?答案是使用微软的dumpbin工具,后面讲了如何使用gcc生成lib和dll
为什么我会考虑这个问题呢?因为我在使用java去调用一个c的lib库的时候,弹出以下警告: D:\work\ideaworkpaces\jdk21Test001\src\main\java\lib\h ...
- Ruby 版本升级
一.升级原因 在开发shopify app的时候,提示我当前的Ruby版本不支持(如下图),所以需要升级Ruby. 由于Ruby 中的一些 Gem 依赖于 OpenSSL 库,所以更改 Ruby 版本 ...
- Web测试基本思路:UI测试、功能测试和兼容性测试
关于网站测试的基本思路,希望对测试小白有所帮助. 一.UI测试 用户界面测试主要是拿待测网页和设计稿进行对比,主要主要以下4点: 1.注重细节: 这点最基本,就是对比是细心.细心再细心. 2.主要整体 ...
- k8s初始化pod-pod标签
目录 initContainers(初始化容器) 静态pod pod的调度策略(将pod指派给特定节点) initContainers(初始化容器) k8s在1.3版本的时候引入了一个初始化容器(in ...
- linux中创建新用户并且放到用户组中
1.打开终端并以 root 用户身份登录到 Linux 系统 2.使用以下命令创建一个新用户 sudo useradd -m username 将 "username" 替换为你要 ...
- curl使用小记(一)
目录 1. 概述 2. 实例 2.1. 访问网页 2.2. 显示头信息 2.3. 保存网页 2.4. 下载图片 2.5. 用户代理设置 2.6. 代理设置 3. 参考 1. 概述 curl也就是com ...
- 华为云GaussDB打造最可信的数据库,给世界一个更优选择
近日,第14届中国数据库技术大会(DTCC2023)在北京国际会议中心顺利举行.大会以"数智赋能 共筑未来"为主题,邀请了上百位行业专家,一起探讨新时代下各类型数据库的最新动态和应 ...
- 大模型高效开发的秘密武器:大模型低参微调套件MindSpore PET
摘要:本文介绍大模型低参微调套件--MindSpore PET. 本文分享自华为云社区<大模型高效开发的秘密武器--大模型低参微调套件MindSpore PET篇>,作者:yd_28087 ...
- 干货时间:聊聊DevOps下的技术系列之契约测试
摘要:本期和大家简单聊聊在服务交互场景下使用服务契约的重要性,以及契约管理的必要性,最后简单介绍了下契约测试. 1.服务交互带来的问题 在上一篇文章中,我们系统的列举了DevOps各个流程中常用的测试 ...