前文

pom.xml文件增加依赖

<!--        Zookeeper依赖-->
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.7.0</version>
</dependency>

新建java文件:ZookeeperTest

/**
* @author LEHOSO
* @date 2021/11/21
* @apinote
*/ public class ZookeeperTest { public static void main(String[] args) throws Exception {
// 初始化ZooKeeper实例(zk地址、会话超时时间,与系统默认一致, watcher)
//步骤一:创建Zookeeper客户端
//参数1:zk地址;参数2:会话超时时间(与系统默认一致);参数3:监视器
ZooKeeper zk = new ZooKeeper(
"192.168.142.10:2181," +
"192.168.142.20:2181," +
"192.168.142.30:2181", 300000, new Watcher() {
@Override
//监控所有被触发的事件(也就是在这里进行事件的处理)
public void process(WatchedEvent watchedEvent) {
System.out.println("事件类型为:" + watchedEvent.getType());
System.out.println("事件发生的路径:" + watchedEvent.getPath());
System.out.println("通知状态为:" + watchedEvent.getState());
}
}); //步骤二:创建目录节点
//参数1:要创建的节点路径;参数2:节点数据;参数3:节点权限;参数4:节点类型
zk.create("/testRootPath", "testRootData".getBytes(),
Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT); //步骤三:创建子目录节点
zk.create("/testRootPath/testChildPathOne", "testChildPathOne".getBytes(),
Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT); //步骤四:获取目录节点数据
//参数1:存储节点数据的路径;
//参数2:是否需要监控此节点(true/false)
//参数3:stat节点的统计信息(一般设置null)
System.out.println("testRootData节点数据为:" +
new String(zk.getData("/testRootPath", false, null)));
//步骤五:获取子目录节点数据
// 取出子目录节点列表
System.out.println(zk.getChildren("/testRootPath", true)); //步骤六:修改子目录节点数据,使得监听触发
//参数1:存储子目录节点数据的路径;
//参数2:要修改的数据;
//参数3:预期要匹配的版本(设置为-1,则可匹配任何节点的版本)
zk.setData("/testRootPath/testChildPathOne", "modifyChildDataOne".getBytes(), -1);
//步骤七:判断目录节点是否存在
System.out.println("目录节点状态[" + zk.exists("/testRootPath", true) + "]"); //步骤八:删除子目录节点
zk.delete("/testRootPath/testChildPathOne", -1);
//步骤九:删除目录节点
zk.delete("/testRootPath", -1);
zk.close();
}
}

GitHub文件下载

HadoopDemo

最新文章

  1. java trim
  2. 10、网页制作Dreamweaver(扩展:各浏览器对 onunload 事件的支持与触发条件实现有差异)
  3. Servlet主要的作用
  4. uvalive 3523 Knights of the Round Table 圆桌骑士(强连通+二分图)
  5. MySQL基础之第11章 插入、更新与删除数据
  6. 【C语言】-条件语句-switch语句
  7. 使用vbs脚本添加域网络共享驱动器
  8. linux的nvme驱动需要关心的统计项
  9. JFinal 极速开发框架的优点和不足的地方
  10. PCA和PCoA
  11. Html5与Css3知识点拾遗(八)
  12. TF版本的Word2Vec和余弦相似度的计算
  13. 4609: [Wf2016]Branch Assignment 最短路 DP (阅读理解题)
  14. (树形dp)鸡毛信问题 (fzu 1227)
  15. JDK 和 JRE 有什么区别
  16. mongodb 3.0下载安装、配置及mongodb最新特性、基本命令教程详细介绍
  17. vue-cli router的使用
  18. Java常用类之String
  19. Discrete cosine transform(离散余弦转换)
  20. Kubernetes TLS认证

热门文章

  1. Java多线程编程实战指南 设计模式 读书笔记
  2. NX二次开发 克隆
  3. Linux Manual
  4. Vue2源码解读 - 响应式原理及简单实现
  5. Sequence Model-week1编程题3-用LSTM网络生成爵士乐
  6. matlab添加永久路径
  7. C++ string类型小结
  8. 15个问题自查你真的了解java编译优化吗?
  9. jmeter 数据库压力测试之MySql
  10. 服务端渲染技术NUXT