2021年大数据ZooKeeper(五):ZooKeeper Java API操作

举报
Lansonli 发表于 2021/09/29 00:27:22 2021/09/29
【摘要】 目录 ZooKeeper Java API操作 引入maven坐标 节点的操作 ZooKeeper Java API操作 这里操作Zookeeper的JavaAPI使用的是一套zookeeper客户端框架 Curator ,解决了很多Zookeeper客户端非常底层的细节开发...

目录

ZooKeeper Java API操作

引入maven坐标

节点的操作


ZooKeeper Java API操作

这里操作Zookeeper的JavaAPI使用的是一套zookeeper客户端框架 Curator ,解决了很多Zookeeper客户端非常底层的细节开发工作 。

Curator包含了几个包:

curator-framework对zookeeper的底层api的一些封装

curator-recipes封装了一些高级特性,如:Cache事件监听、选举、分布式锁、分布式计数器等

Maven依赖(使用curator的版本:2.12.0,对应Zookeeper的版本为:3.4.x,如果跨版本会有兼容性问题,很有可能导致节点操作失败):

​​​​​​​引入maven坐标


      <dependencies>
              <dependency>
                  <groupId>org.apache.curator</groupId>
                  <artifactId>curator-framework</artifactId>
                  <version>2.12.0</version>
              </dependency>
              <dependency>
                  <groupId>org.apache.curator</groupId>
                  <artifactId>curator-recipes</artifactId>
                  <version>2.12.0</version>
              </dependency>
              <dependency>
                  <groupId>com.google.collections</groupId>
                  <artifactId>google-collections</artifactId>
                  <version>1.0</version>
              </dependency>
              <dependency>
                  <groupId>junit</groupId>
                  <artifactId>junit</artifactId>
                  <version>RELEASE</version>
              </dependency>
              <dependency>
                  <groupId>org.slf4j</groupId>
                  <artifactId>slf4j-simple</artifactId>
                  <version>1.7.25</version>
              </dependency>
          </dependencies>
          <build>
              <plugins>
                  <!-- java编译插件 -->
                  <plugin>
                      <groupId>org.apache.maven.plugins</groupId>
                      <artifactId>maven-compiler-plugin</artifactId>
                      <version>3.2</version>
                      <configuration>
                          <source>1.8</source>
                          <target>1.8</target>
                          <encoding>UTF-8</encoding>
                      </configuration>
                  </plugin>
              </plugins>
         </build>
  
 

​​​​​​​节点的操作


      /*
       创建节点
       */
      @Test
      public void createZnode() throws Exception {
      //1:定制一个重试策略
      /*
      param1: 重试的间隔时间
      param2:重试的最大次数
       */
      RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000,1);
      //2:获取一个客户端对象
      /*
         param1:要连接的Zookeeper服务器列表
         param2:会话的超时时间
         param3:链接超时时间
         param4:重试策略
       */
      String connectionStr = "192.168.88.161:2181,192.168.88.162:2181,192.168.88.163:2181";
      CuratorFramework client = CuratorFrameworkFactory.newClient(connectionStr, 8000, 8000, retryPolicy);
      //3:开启客户端
      client.start();
      //4:创建节点
      /*
        节点类型:
         CreateMode.PERSISTENT:永久节点
         CreateMode.PERSISTENT_SEQUENTIAL:永久序列化节点
         CreateMode.EPHEMERAL:临时节点
         CreateMode.EPHEMERAL_SEQUENTIAL:临时序列化节点
         /hello2 :节点路径
         world :节点数据
       */
      client.create().creatingParentsIfNeeded().withMode(CreateMode.PERSISTENT).forPath("/hello2","world".getBytes());
      //5:关闭客户端
      client.close();
      }
  
 

文章来源: lansonli.blog.csdn.net,作者:Lansonli,版权归原作者所有,如需转载,请联系作者。

原文链接:lansonli.blog.csdn.net/article/details/117136304

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。