Zookeeper入门看这篇就够了,java图形界面开发视频教程

  1. get命令获取创建Znode的内容

get /zkMxn

  1. set 命令来对 zk 所关联的字符串进行设置

set /zkMxn mxn666

  1. 删除Znode

delete /zkMxn

Java Api操作 ZK


1. 导入Jar包

org.apache.zookeeper

zookeeper

3.6.3

junit

junit

4.13.2

runtime

2. API操作Zookeeper

创建Zookeeper对象

public ZooKeeper(String connectString, int sessionTimeout, Watcher watcher) throws IOException {

this(connectString, sessionTimeout, watcher, false);

}

  • connectString: 连接的地址,包括主机名和端口号,多个的话用逗号隔开

  • sessionTimeout: 等待客户端通信的最长时间,客户端如果超过这个时间没有和服务端进行通信,那么就认为该客户端已经终止,一般设置值为 5-10秒,单位为毫秒

  • watcher: 监听器,用于接收会话事件的接口,需要自己定义,实现process()方法

连接Zookeeper

Zookeeper zkClient = “”;

String connectStr = “192.168.2.1:2181”;

zkClient = new ZooKeeper(connectStr, 5000, new Watcher() {

@Override

public void process(WatchedEvent watchedEvent) { }

});

创建节点

public String create(String path, byte[] data, List acl, CreateMode createMode) throws KeeperException, InterruptedException {}

  • path: 节点路径

  • data: 节点数据

  • acl: 节点权限,例如:ZooDefs.Ids.OPEN_ACL_UNSAFE

OPEN_ACL_UNSAFE:完全开发,采用world验证模式,由于每个ZK连接都有world验证模式,所以当我们节点设置了该参数时,对所有连接开放

CREATOR_ALL_ACL: 创建该Znode连接的拥有所有权限,这里采用的是auth验证模式,用sessionID做验证,如果设置了该参数,只有创建改Znode节点的连接才能对这个Znode进行任何操作

READ_ACL_UNSAFE:所有的客户端都可读,这里采用world验证模式,和第一条同理,所有连接都可以读取该znode

  • createMode: 节点类型,例如:CreateMode.PERSISTENT

PERSISTENT:持久节点

PERSISTENT_SEQUENTIAL:持久有序节点

EPHEMERAL:短暂节点

EPHEMERAL_SEQUENTIAL:短暂有序节点

完整APIDemo:

import lombok.extern.slf4j.Slf4j;

import org.apache.zookeeper.*;

import org.apache.zookeeper.data.Stat;

import java.io.IOException;

import java.io.UnsupportedEncodingException;

import java.util.concurrent.CountDownLatch;

/** @Author mxn

  • @Description //TODO ZooKeeper Java API测试

  • @Date 10:22 2021/9/29

  • @Param

  • @return

**/

@Slf4j

public class ZookeeperTest {

// IP 和端口

private final static String ipAddress = “192.168.2.123:2181”;

public static void main(String[] args) {

ZookeeperTest test = new ZookeeperTest();

String key = “/zkMxn”;

String value = “wo is muxiaonong”;

//创建Znode

test.add(key,value);

// 获取节点数据

// test.get(key);

//修改节点数据

// test.modify(key,“wo is zhuzhuxia”);

//删除节点

// test.delete(key);

}

/**

  • @return

  • @Author mxn

  • @Description //TODO 获取ZooKeeper连接

  • @Date 10:22 2021/9/29

  • @Param

**/

public static ZooKeeper getConntection() {

ZooKeeper zooKeeper = null;

try {

final CountDownLatch countDownLatch = new CountDownLatch(1);

//watch机制(回调),监听是否连接成功

zooKeeper = new ZooKeeper(ipAddress, 5000, new Watcher() {

@Override

public void process(WatchedEvent watchedEvent) {

if (Event.KeeperState.SyncConnected == watchedEvent.getState()) {

//如果受收到了服务端的响应事件,连接成功

countDownLatch.countDown();

}

}

});

countDownLatch.await();

log.info(“zookeeper状态:{}”,zooKeeper.getState());//CONNECTED

} catch (IOException e) {

e.printStackTrace();

} catch (InterruptedException e) {

e.printStackTrace();

}

return zooKeeper;

}

/** @Author lyy

  • @Description //TODO 关闭ZooKeeper连接

  • @Date 14:57 2021/9/29

  • @Param

  • @return

**/

public static void closeConnection(ZooKeeper zooKeeper) {

try {

// zooKeeper.close();

} catch (Exception e) {

e.printStackTrace();

}

}

/** @Author lyy

  • @Description //TODO 添加节点

  • @Date 13:36 2021/9/29

  • @Param

  • @return

**/

public void add(String key ,String value) {

ZooKeeper zooKeeper = ZookeeperTest.getConntection();

try {

//参数类型

//1.key

//2.value

//3.对应的ACL,当前节点的权限控制

//4.设置当前节点类型

zooKeeper.create(key, value.getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);

ZookeeperTest.closeConnection(zooKeeper);

} catch (KeeperException e) {

e.printStackTrace();

} catch (InterruptedException e) {

e.printStackTrace();

}

}

/** @Author lyy

  • @Description //TODO 获取节点信息

  • @Date 14:57 2021/9/29

  • @Param

  • @return

**/

public void get(String key) {

ZooKeeper zooKeeper = ZookeeperTest.getConntection();

Stat stat = new Stat();

String data = null;

try {

byte[] bytes = zooKeeper.getData(key, null, stat);

data = new String(bytes, “gbk”);

log.info(“当前节点信息:{}”,data);

ZookeeperTest.closeConnection(zooKeeper);

} catch (KeeperException e) {

e.printStackTrace();

} catch (InterruptedException e) {

e.printStackTrace();

} catch (UnsupportedEncodingException e) {

e.printStackTrace();

}

}

/** @Author lyy

  • @Description //TODO 修改节点信息

  • @Date 14:57 2021/9/29

  • @Param

  • @return

**/

public void modify(String key,String newValue) {

ZooKeeper zooKeeper = ZookeeperTest.getConntection();

Stat stat = new Stat();

//version乐观锁概念,此处需要获取version信息,则需要先get拿到节点信息

try {

//获取节点(修改需要version信息)

zooKeeper.getData(key, null, stat);

//再修改

zooKeeper.setData(key, newValue.getBytes(), stat.getVersion());

ZookeeperTest.closeConnection(zooKeeper);

} catch (KeeperException e) {

e.printStackTrace();

} catch (InterruptedException e) {

e.printStackTrace();

}

}

/** @Author lyy

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
img

分享

1、算法大厂——字节跳动面试题

2、2000页互联网Java面试题大全

3、高阶必备,算法学习

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img

点,真正体系化!**

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-aJyWGIPt-1712783231262)]

分享

1、算法大厂——字节跳动面试题

[外链图片转存中…(img-GC4ZYPy3-1712783231263)]

2、2000页互联网Java面试题大全

[外链图片转存中…(img-ciTuLwR9-1712783231263)]

3、高阶必备,算法学习

[外链图片转存中…(img-ICiInr82-1712783231263)]

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-ffQZWRCl-1712783231263)]

  • 26
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值