前面介绍了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客户端的使用的更多相关文章

  1. Zookeeper的java客户端API使用方法(五)

    前面几篇博文,我们简单的介绍了一下zookeeper,如何安装zookeeper集群,以及如何使用命令行等.这篇博文我们重点来看下Zookeeper的java客户端API使用方式. 创建会话 客户端可 ...

  2. ZooKeeper学习总结(2)——ZooKeeper开源Java客户端ZkClient使用

    zkclient是zookeeper的Java客户端.它让Zookeeper API 使用起来更简单:它非常方便订阅各种事件并自动重新绑定事件(会话建立.节点修改.节点删除.子节点变更等):它提供了s ...

  3. zookeeper的Java客户端API

    zookeeper作为一个分布式服务框架,主要用来解决分布式数据一致性问题,对多种语言提供了API.这里主要记录下JAVA客户端API的使用. 1.创建会话 客户端可以通过创建一个ZooKeeper实 ...

  4. 02.ZooKeeper的Java客户端使用

    1.ZooKeeper常用客户端比较 1.ZooKeeper常用客户端     zookeeper的常用客户端有3种,分别是:zookeeper原生的.Apache Curator.开源的zkclie ...

  5. Zookeeper 的 java 客户端都有哪些?

    java 客户端:zk 自带的 zkclient 及 Apache 开源的 Curator.

  6. [转载] ZooKeeper的Java客户端API

    转载自 http://www.cnblogs.com/ggjucheng/p/3370359.html http://zookeeper.apache.org/doc/trunk/javaExampl ...

  7. 六:ZooKeeper的java客户端api的使用

    一:客户端链接测试 package com.yeepay.sxf.createConnection; import java.io.IOException; import org.apache.zoo ...

  8. ZooKeeper:Java客户端网络处理

    了解ZooKeeper客户端的实现,对于使用ZooKeeper的客户端非常重要. 通过对客户端源码的阅读,了解了如下信息: 创建ZooKeeper对象时,应会创建一个ClientCnxn(代表了客户端 ...

  9. 12. ZooKeeper之Java客户端API使用—创建会话。

    转自:https://blog.csdn.net/en_joker/article/details/78686649 客户端可以通过创建一个ZooKeeper(org.apache.zookeeper ...

  10. 13.Zookeeper的java客户端API使用方法

    转自:https://blog.csdn.net/jiuqiyuliang/article/details/56012027

随机推荐

  1. RocksDB 在 vivo 消息推送系统中的实践

    作者:vivo 互联网服务器团队 - Zeng Luobin 本文主要介绍了 RocksDB 的基础原理,并阐述了 RocksDB 在vivo消息推送系统中的一些实践,通过分享一些对 RocksDB ...

  2. FOJ有奖月赛-2015年11月 Problem B 函数求解

    Problem B 函数求解 Accept: 171    Submit: 540Time Limit: 1000 mSec    Memory Limit : 32768 KB  Problem D ...

  3. 开源MES/免费MES/开源mes 生产管理流程

    开源MES/免费MES/开源MES生产流程管理 一.什么是MES生产管理流程 生产管理系统(又称制造执行系统)是一种集成了计划.生产.质量控制.库存管理和材料申请等生产流程的管理系统.工厂生产管理流程 ...

  4. Python——第二章:range()的用法:

    在Python中,range()是一个内置函数,用于生成一个整数序列,通常用于循环遍历.以下是range()函数的一些常见用法: range(n): 从0数到n. 不包含nrange(m, n): 从 ...

  5. JavaFx设置图标(二)

    JavaFx设置图标(二) JavaFX 从入门入门到入土系列 JavaFx设置图标,需要注意,我这里是Maven管理项目 需要将图片放到resources/img/avatar.jpg下 impor ...

  6. UE5: UpdateOverlap - 从源码深入探究UE的重叠触发

    前言 出于工作需要和个人好奇,本文对UE重叠事件更新的主要函数UpdateOverlaps从源码的角度进行了详细的分析,通过阅读源码,深入理解重叠事件是如何被触发和更新的. 解决问题 阅读本文,你将得 ...

  7. java中获取公网IP

    package com.dashan.utils.iputils; import org.apache.commons.lang.StringUtils; import java.io.Buffere ...

  8. 实战案例丨使用云连接CC和数据复制服务DRS实现跨区域RDS迁移和数据同步

    摘要:实践案例展示如何使用云连接CC和数据复制服务DRS实现跨区域RDS迁移和数据同步. [业务场景及诉求] 希望将不同区域"华北-北京四"的rds与"亚太-新加坡&qu ...

  9. 代码也能“杀”虫:此虫,真虫非Bug也

    摘要:看这群大学生如何保护粮食,让害虫.霉变无处遁形. 国以民为本,民以食为天,对有着14亿人口的中国来说,粮食安全,一直都是关系国计民生的头等大事. 2010年以来,我国人均粮食占有量持续高于世界平 ...

  10. 昇腾CANN:为你开启机器人开发的Buff 加成

    摘要:昇腾AI提供了全栈技术和产品,构筑人工智能的算力基座,赋能上层应用 本文分享自华为云社区<昇腾CANN:为你开启机器人开发的Buff 加成>,作者:华为云社区精选 . 昇腾AI基础软 ...