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坐标


  
  1. <dependencies>
  2.         <dependency>
  3.             <groupId>org.apache.curator</groupId>
  4.             <artifactId>curator-framework</artifactId>
  5.             <version>2.12.0</version>
  6.         </dependency>
  7.         <dependency>
  8.             <groupId>org.apache.curator</groupId>
  9.             <artifactId>curator-recipes</artifactId>
  10.             <version>2.12.0</version>
  11.         </dependency>
  12.         <dependency>
  13.             <groupId>com.google.collections</groupId>
  14.             <artifactId>google-collections</artifactId>
  15.             <version>1.0</version>
  16.         </dependency>
  17.         <dependency>
  18.             <groupId>junit</groupId>
  19.             <artifactId>junit</artifactId>
  20.             <version>RELEASE</version>
  21.         </dependency>
  22.         <dependency>
  23.             <groupId>org.slf4j</groupId>
  24.             <artifactId>slf4j-simple</artifactId>
  25.             <version>1.7.25</version>
  26.         </dependency>
  27.     </dependencies>
  28.     <build>
  29.         <plugins>
  30.             <!-- java编译插件 -->
  31.             <plugin>
  32.                 <groupId>org.apache.maven.plugins</groupId>
  33.                 <artifactId>maven-compiler-plugin</artifactId>
  34.                 <version>3.2</version>
  35.                 <configuration>
  36.                     <source>1.8</source>
  37.                     <target>1.8</target>
  38.                     <encoding>UTF-8</encoding>
  39.                 </configuration>
  40.             </plugin>
  41.         </plugins>
  42.    </build>

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


  
  1. /*
  2.  创建节点
  3.  */
  4. @Test
  5. public void createZnode() throws Exception {
  6. //1:定制一个重试策略
  7. /*
  8. param1: 重试的间隔时间
  9. param2:重试的最大次数
  10.  */
  11. RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000,1);
  12. //2:获取一个客户端对象
  13. /*
  14.    param1:要连接的Zookeeper服务器列表
  15.    param2:会话的超时时间
  16.    param3:链接超时时间
  17.    param4:重试策略
  18.  */
  19. String connectionStr = "192.168.88.161:2181,192.168.88.162:2181,192.168.88.163:2181";
  20. CuratorFramework client = CuratorFrameworkFactory.newClient(connectionStr, 80008000, retryPolicy);
  21. //3:开启客户端
  22. client.start();
  23. //4:创建节点
  24. /*
  25.   节点类型:
  26.    CreateMode.PERSISTENT:永久节点
  27.    CreateMode.PERSISTENT_SEQUENTIAL:永久序列化节点
  28.    CreateMode.EPHEMERAL:临时节点
  29.    CreateMode.EPHEMERAL_SEQUENTIAL:临时序列化节点
  30.    /hello2 :节点路径
  31.    world :节点数据
  32.  */
  33. client.create().creatingParentsIfNeeded().withMode(CreateMode.PERSISTENT).forPath("/hello2","world".getBytes());
  34. //5:关闭客户端
  35. client.close();
  36. }

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

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

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

评论(0

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

全部回复

上滑加载中

设置昵称

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

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

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