java操作zookeeper

这篇具有很好参考价值的文章主要介绍了java操作zookeeper。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

java操作zookeeper

  1. 创建一个maven项目在pom文件里引入如下依赖:
<dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.10</version>
      <scope>test</scope>
    </dependency>
    <!-- curator-->
    <dependency>
      <groupId>org.apache.curator</groupId>
      <artifactId>curator-framework</artifactId>
      <version>4.0.0</version>
    </dependency>
    <dependency>
      <groupId>org.apache.curator</groupId>
      <artifactId>curator-recipes</artifactId>
      <version>4.0.0</version>
    </dependency>
    <!-- 日志 -->
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-api</artifactId>
      <version>1.7.21</version>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-log4j12</artifactId>
      <version>1.7.21</version>
    </dependency>
</dependencies>
  1. 创建一个测试类进行相关操作的测试
  • 连接客户端
 @Before
 public void testConnect(){
        ExponentialBackoffRetry retryPolicy = new ExponentialBackoffRetry(3000, 10);
        client = CuratorFrameworkFactory.builder() // 使用工厂类来建造客户端的实例对象
                .connectString("192.168.223.131:2181") // 指定连接zookeeper的服务器地址
                .retryPolicy(retryPolicy) // 指定重试策略
                .namespace("test") // 指定命名空间
                .build(); // 建造客户端实例对象
        client.start(); // 启动客户端
    }
  • 关闭客户端
 @After
 public void testClose(){
        // 关闭客户端
        if (client != null){
            client.close();
        }
    }
  • 创建节点
@Test
public void testCreateNode() throws Exception {
        // 如果没有指定命名空间,那么节点的完整路径为 /node2,如果指定了命名空间,那么节点的完整路径为 /test/node2
        // 如果没有数据,那么节点的数据为当前客户端的ip地址
        // 如果没有指定节点类型,那么节点类型为持久节点
        // CreateMode.EPHEMERAL 临时节点
        // creatingParentsIfNeeded() 如果父节点不存在,那么自动创建父节点
        String path = client.create()
                .creatingParentsIfNeeded()
                .withMode(CreateMode.EPHEMERAL)
                .forPath("/node3/min", "node3min".getBytes());
        System.out.println(path);
        // 让线程阻塞,不让程序结束,这样可以在zookeeper中看到创建的临时节点,因为临时节点的生命周期是和客户端绑定的
        Thread.sleep(100000);
    }
  • 获取节点数据
@Test
public void testGetData() throws Exception {
        byte[] bytes = client.getData().forPath("/node2");
        System.out.println(new String(bytes));
    }
  • 查询子节点
 @Test
 public void testGetChildren() throws Exception {
        List<String> childrenList = client.getChildren().forPath("/");
        for (String child : childrenList) {
            System.out.println(child);
        }
    }
  • 查询节点状态信息
 @Test
 public void testGetStat() throws Exception {
        // Stat类用于存储节点状态信息
        Stat stat = new Stat();
        // storingStatIn(stat) 将节点状态信息存储到stat对象中
        byte[] data = client.getData().storingStatIn(stat).forPath("/node2");
        System.out.println(new String(data));
        System.out.println(stat);
    }
  • 更新节点数据
@Test
public void testSetData() throws Exception {
        client.setData().forPath("/node2/min1", "minqiliang".getBytes());
    }
  • 更新节点数据,带版本号
@Test
public void testSetDataWithVersion() throws Exception {
        Stat stat = new Stat();
        client.getData().storingStatIn(stat).forPath("/node3");
        System.out.println(stat.getVersion());
        client.setData().withVersion(stat.getVersion()).forPath("/node3", "minqiliang".getBytes());
    }
  • 删除节点
@Test
public void testDeleteNode() throws Exception {
        // deletingChildrenIfNeeded() 如果存在子节点,那么先删除子节点,再删除父节点
        client.delete().deletingChildrenIfNeeded().forPath("/node2");
    }
  • 删除节点,必须成功
@Test
public void testDeleteNodeWithVersion() throws Exception {
        // guaranteed() 如果删除失败,那么会在后台一直尝试删除,直到删除成功为止
        client.delete().guaranteed().forPath("/node3");
    }
  • 删除节点,回调函数
@Test
public void testDeleteNodeWithCallback() throws Exception {
        // inBackground() 指定回调函数
        client.delete().guaranteed().inBackground((client, event) -> System.out.println(event)).forPath("/node3");
        Thread.sleep(100000);
    }
  • 监听节点的创建、修改、删除
 @Test
 public void testNodeCache() throws Exception {
        // 创建一个nodeCache对象
        NodeCache nodeCache = new NodeCache(client, "/node3");
        // 注册监听器
        nodeCache.getListenable().addListener(() -> {
            System.out.println("节点数据发生变化");
            byte[] bytes = nodeCache.getCurrentData().getData();
            System.out.println(new String(bytes));
        });
        // 启动监听器
        nodeCache.start(true);
        while (true){

        }
    }
  • 监听子节点的创建、修改、删除
@Test
public void testpathChildrenCache() throws Exception {
        // 创建一个nodeCache对象
        PathChildrenCache pathChildrenCache = new PathChildrenCache(client, "/node3",true);
        // 注册监听器
        pathChildrenCache.getListenable().addListener((client,event) -> {
            System.out.println("节点数据发生变化");
            System.out.println(event);
            PathChildrenCacheEvent.Type type = event.getType();
            if (type.equals(PathChildrenCacheEvent.Type.CHILD_UPDATED)){
                System.out.println("子节点数据发生变化");
                byte[] data = event.getData().getData();
                System.out.println(new String(data));
            }
        });
        // 启动监听器
        pathChildrenCache.start(true);
        while (true){

        }
    }
  • 树形监听器
 @Test
 public void testTreeCache() throws Exception {
        // 创建一个nodeCache对象
            TreeCache treeCache = new TreeCache(client, "/node3");
        // 注册监听器
        treeCache.getListenable().addListener((client,event) -> {
            System.out.println("节点数据发生变化");
            System.out.println(event);
            TreeCacheEvent.Type type = event.getType();
            if (type.equals(TreeCacheEvent.Type.NODE_UPDATED)){
                System.out.println("子节点数据发生变化");
                byte[] data = event.getData().getData();
                System.out.println(new String(data));
            }
        });

        // 启动监听器
        treeCache.start();
        while (true){

        }
    }
  1. 分布式锁
InterProcessMutex lock = new InterProcessMutex(client, "/lock");
// 获取锁
try {
    // 获取锁
    boolean acquire = lock.acquire(3, TimeUnit.SECONDS);
}catch (Exception e) {
   e.printStackTrace();
}finally {
  // 释放锁
  try {
      lock.release();
   } catch (Exception e) {
      e.printStackTrace();
   }              
}

文章来源地址https://www.toymoban.com/news/detail-564649.html

到了这里,关于java操作zookeeper的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • java操作zookeeper

    创建一个maven项目在pom文件里引入如下依赖: 创建一个测试类进行相关操作的测试 连接客户端 关闭客户端 创建节点 获取节点数据 查询子节点 查询节点状态信息 更新节点数据 更新节点数据,带版本号 删除节点 删除节点,必须成功 删除节点,回调函数 监听节点的创建、修

    2024年02月16日
    浏览(40)
  • Java操作Zookeeper节点

    引入jar包: zookeeper的权限: ZooKeeper提供了如下几种验证模式(scheme): • digest:Client端由用户名和密码验证,譬如user:password,digest的密码生成方式是Sha1摘要的base64形式 • auth:不使用任何id,代表任何已确认用户。 • ip:Client端由IP地址验证,譬如172.2.0.0/24 • world:固定

    2024年02月10日
    浏览(40)
  • 【Java——maven的使用与idea创建maven项目,导入maven依赖(jar包)】

    1.1、打开maven安装路径下的conf文件夹,找到里面的settings.xml文件,(如果使用的是maven安装程序安装的maven,则settings.xml文件和本地仓库位置在默认位置:C:Userspenglei.m2)将下面的代码复制里面,切记不要放到注释里面 1.2、maven项目全局默认配置jdk版本信息,将下面的代码复制

    2024年02月08日
    浏览(90)
  • 六、ZooKeeper Java API操作

    目录 1、引入maven坐标 2、节点的操作 这里操作Zookeeper的JavaAPI使用的是一套zookeeper客户端框架 Curator ,解决了很多Zookeeper客户端非常底层的细节开发工作 。 Curator包含了几个包:

    2024年02月04日
    浏览(33)
  • ZooKeeper基础命令和Java客户端操作

    (1)Help (2)ls 使用 ls 命令来查看当前znode中所包含的内容 (3)ls2查看当前节点数据并能看到更新次数等数据 (4)stat查看节点状态 (5)set 1)设置节点的具体值 2)set 节点 value值 set /test atguigu (6)get 1)获得节点的值 2)get 节点 (7)create 1)普通创建 create /test demo001

    2024年02月10日
    浏览(52)
  • IDEA项目实践——创建Java项目以及创建Maven项目案例、使用数据库连接池创建项目简介

    IDEA上面书写wordcount的Scala文件具体操作 IDEA创建项目的操作步骤以及在虚拟机里面创建Scala的项目简单介绍 目录 系列文章目录 前言 一 准备工作 1.1 安装Maven 1.1.1 Maven安装配置步骤 1.1.2 解压相关的软件包 1.1.3 Maven 配置环境变量 1.1.4 配置Maven的私服 1.2 创建一个本地的MySQL数据

    2024年02月04日
    浏览(66)
  • 基于 IDEA 创建 Maven 的 Java SE 工程和 Java Web 工程

             Maven 工程相对之前的项目,多出一组 gavp 属性, gav 需要我们在创建项目的时候指定, p 有默认值,我们先行了解下这组属性的含义。          Maven 中的 GAVP 是指 GroupId 、 ArtifactId 、 Version 、 Packaging 等四个属性的缩写,其中前三个是必要的,而 Packaging 属性

    2024年01月17日
    浏览(50)
  • Java客户端_zkclient库操作Zookeeper

    使用zookeeper遇到问题: 重复注册watcher session失效重连 异常处理(删除节点不能有子节点,新增节点必须有父节点等) zkclient是Github上一个开源的Zookeeper客户端,在Zookeeper原生 API接口之上进行了包装,是一个更加易用的Zookeeper客户端。同时Zkclient在内部实现了诸如Session超时重

    2024年02月07日
    浏览(60)
  • ZooKeeper Java API 使用教程 - 同步与异步操作示例

    本教程详细介绍了如何使用ZooKeeper Java API进行节点数据的同步和异步获取。通过具体代码示例,展示了如何连接ZooKeeper服务器,获取子节点列表,以及如何处理节点数据变化的事件。

    2024年04月22日
    浏览(35)
  • IDEA 将一个普通Java工程转化为maven工程

    打开IntelliJ IDEA并打开Java工程。 在项目窗口中,右键单击项目名称,选择“Add Framework Support”。 在弹出的窗口中,选择“Maven”。 在“Maven Information”窗口中,填写Group Id、Artifact Id和Version等基本信息。 点击“Finish”按钮,IntelliJ IDEA会自动创建一个pom.xml文件并将Java工程转化

    2024年02月04日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包