首页 > 编程语言 >java操作zookeeper

java操作zookeeper

时间:2023-07-15 18:23:35浏览次数:42  
标签:java void zookeeper System client println 操作 节点 out

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();
   }              
}

标签:java,void,zookeeper,System,client,println,操作,节点,out
From: https://www.cnblogs.com/minqiliang/p/17556642.html

相关文章

  • java—运行时常量池(Runtime Constant Pool)、常量池(Constant Pool)、字符串常量池(String
    最近在看常量池相关的东西的时候,会被这几个常量池给弄的晕乎乎的查阅了《深入理解java虚拟机》总结如下:一、常量池共有三类:’运行时常量池(RuntimeConstantPool)常量池(ConstantPool):也是常说的class文件常量池(classconstantpool)字符串常量池(StringConstantPool)二、详解......
  • JavaWeb
    JavaWeb基本概念1.1前言web开发:web:网页的意思静态webhtml,css提供给所有人看的数据始终不会发生变化动态web提供给所有人看的数据始终会发生变化,每个人在不同的时间不同的地点看到的信息各不相同。几乎所有的网站。技术栈:Servlet/JSP,ASP,PHP......
  • java时间处理
    LocalDateTimelocalDateTime=LocalDateTime.now();LocalDateTimeminTime=localDateTime.with(LocalTime.MIN);LocalDateTimemaxTime=localDateTime.with(LocalTime.MAX);Set<String>times=DateUtils.getTimes(Date.from(minTime......
  • Java基础1
    Java基础1whitchbreak,可以使用在switch-case结构中,表示一旦执行到此关键字,就跳出switch-case结构switch结构中的表达式,只能是如下的6种数据类型之一:byte.short、char、int、枚举类型(JDK5.0新增)、String类型(JDK7.0新增)case之后只能声明常量。不能声明范围。break关......
  • Java标识符和关键字
    Java标识符和关键字标识符Java所有的组成部分都需要名字类名.变量名以及方法名都被称为标识符注意点:所有的标识符都应该以(AZ或者az),美元符($),或者下划线开始首字符之后可以是字母(AZ或者az),美元符($),下划线(_)或数字的任何字符组合不能使用关键字作为变量名或......
  • 如何使用C#中的Lambda表达式操作Redis Hash结构,简化缓存中对象属性的读写操作
    Redis是一个开源的、高性能的、基于内存的键值数据库,它支持多种数据结构,如字符串、列表、集合、散列、有序集合等。其中,Redis的散列(Hash)结构是一个常用的结构,今天跟大家分享一个我的日常操作,如何使用Redis的散列(Hash)结构来缓存和查询对象的属性值,以及如何用Lambda表达式树来简化......
  • MySQL学习-基本操作
    1.数据库操作创建数据库createdatabasetest;查看数据库showdatabases;进入数据库usetest;删除数据库dropdatabasetest;2.表格操作创建表格 createtabletable1(namevarchar(20),date1date)删除表格droptabletest1修改表格表项altertabletable1modif......
  • office软件提示“您的组织策略阻止我们进行该操作”错误的解决办法-终极汇总
    环境系统:win1064位专业版时间:2023年7月15日1.选择默认软件在设置中打开默认应用,将web浏览器改为你想要的浏览器 2.修改注册表同时按下win+R,输入regedit打开注册表。修改计算机\HKEY_CURRENT_USER\Software\Classes\.html路径下的值为Htmlfile 3.重启office软件或......
  • 启动Hadoop时需要进行的操作
    首先切换到hadoop用户su-hadoop启动hdfs集群start-dfs.sh启动yarn集群start-yarn.sh启动hive首先切换到hive文件夹cd/export/server/hive然后再运行下述命令#先启动metastore服务然后启动hiveserver2服务nohupbin/hive--servicemetastore>>logs/metastore.log......
  • 从头学Java17-今天的Kotlin更香吗
    出于各种限制,很多公司依然停留在Java8,部分小伙伴转向了Kotlin。Kotlin作为静态编译语言,提供大量语法糖,而且编译后的字节码跟Java一致。当时,Java8于2014年发布,Kotlin于2016年,很多宣称的语法糖都是对比的Java8。不禁要问,相对今天的Java17,Kotlin优势还在吗?现在就用最新的Kotlin1.9......