Apache Curator简单介绍

2024-06-10 02:08
文章标签 简单 介绍 apache curator

本文主要是介绍Apache Curator简单介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文链接:https://www.dubby.cn/detail.html?id=9099

提供了一个抽象级别更高的API,来操作Zookeeper,类似Guava提供的很多工具,让Java书写起来更加方便。至于有没有用,那就要看每个人自己的理解了。

1、依赖

<dependency><groupId>org.apache.curator</groupId><artifactId>curator-framework</artifactId><version>2.8.0</version>
</dependency>

更多版本和依赖

2、连接Zookeeper

RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000, 3);
CuratorFramework client = CuratorFrameworkFactory.newClient("127.0.0.1:2181", retryPolicy);
client.start();

3、增删改查

/*** Zookeeper的CRUD操作*/
public class CrudExamples {/*** 给指定的ZNode设置值,不能嵌套创建目录* 如果节点已经存在,会抛异常org.apache.zookeeper.KeeperException$NodeExistsException: KeeperErrorCode = NodeExists for /path*/public static void create(CuratorFramework client, String path, byte[] payload) throws Exception {client.create().forPath(path, payload);}/*** 创建临时节点* 需要注意:虽说临时节点是session失效后立刻删除,但是并不是client一断开连接,session就立刻会失效* 失效是由zk服务端控制的,每次连接时,客户端和服务端会协商一个合理的超时时间* 如果超过了超时时间client都一直美哦与发送心跳,才回真的删除这个session创建的临时节点*/public static void createEphemeral(CuratorFramework client, String path, byte[] payload) throws Exception {client.create().withMode(CreateMode.EPHEMERAL).forPath(path, payload);}public static String createEphemeralSequential(CuratorFramework client, String path, byte[] payload) throws Exception {return client.create().withProtection().withMode(CreateMode.EPHEMERAL_SEQUENTIAL).forPath(path, payload);}public static void setData(CuratorFramework client, String path, byte[] payload) throws Exception {client.setData().forPath(path, payload);}public static void setDataAsync(CuratorFramework client, String path, byte[] payload) throws Exception {CuratorListener listener = new CuratorListener() {@Overridepublic void eventReceived(CuratorFramework client, CuratorEvent event) throws Exception {if (event != null)System.out.println(event.toString());}};client.getCuratorListenable().addListener(listener);client.setData().inBackground().forPath(path, payload);}public static void setDataAsyncWithCallback(CuratorFramework client, BackgroundCallback callback, String path, byte[] payload) throws Exception {client.setData().inBackground(callback).forPath(path, payload);}public static void delete(CuratorFramework client, String path) throws Exception {client.delete().forPath(path);}public static void guaranteedDelete(CuratorFramework client, String path) throws Exception {client.delete().guaranteed().forPath(path);}public static List<String> watchedGetChildren(CuratorFramework client, String path) throws Exception {return client.getChildren().watched().forPath(path);}public static List<String> watchedGetChildren(CuratorFramework client, String path, Watcher watcher) throws Exception {return client.getChildren().usingWatcher(watcher).forPath(path);}
}

使用上面的增删改查来测试:

public class CuratorStartupDemo {private static CuratorFramework CLIENT;private static final String CHARSET = "UTF-8";static {RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000, 3);CLIENT = CuratorFrameworkFactory.newClient("127.0.0.1:2181", retryPolicy);}public static void main(String[] args) throws Exception {CLIENT.start();System.out.println(CLIENT.getZookeeperClient().getConnectionTimeoutMs());CrudExamples.create(CLIENT, "/x", "test".getBytes(CHARSET));CrudExamples.createEphemeral(CLIENT, "/e", "test".getBytes(CHARSET));CrudExamples.setData(CLIENT, "/x", UUID.randomUUID().toString().getBytes(CHARSET));CrudExamples.setDataAsync(CLIENT, "/x", UUID.randomUUID().toString().getBytes(CHARSET));CrudExamples.setDataAsyncWithCallback(CLIENT, ((client, event) -> {System.out.println(event.getPath());}), "/x", UUID.randomUUID().toString().getBytes(CHARSET));CrudExamples.createEphemeralSequential(CLIENT, "/x", "test".getBytes(CHARSET));CrudExamples.createEphemeralSequential(CLIENT, "/x", "test".getBytes(CHARSET));CrudExamples.createEphemeralSequential(CLIENT, "/x", "test".getBytes(CHARSET));CrudExamples.createEphemeralSequential(CLIENT, "/x", "test".getBytes(CHARSET));CuratorListener listener = new CuratorListener() {@Overridepublic void eventReceived(CuratorFramework client, CuratorEvent event) throws Exception {if (event != null)System.out.println(event.toString());//watcher是一次性的,每次watch后需要重新设置watcherif ("/x".equals(event.getPath())) {CrudExamples.watchedGetChildren(CLIENT, "/x");}}};CLIENT.getCuratorListenable().addListener(listener);CrudExamples.watchedGetChildren(CLIENT, "/x");CrudExamples.create(CLIENT, "/x/a", null);CrudExamples.create(CLIENT, "/x/b", null);CrudExamples.delete(CLIENT, "/x/a");CrudExamples.delete(CLIENT, "/x/b");MyWatcher myWatcher = new MyWatcher("/x", CLIENT);CrudExamples.watchedGetChildren(myWatcher.curatorFramework, myWatcher.getPath(), myWatcher);System.out.println("task completed");new CountDownLatch(1).await();}static class MyWatcher implements Watcher {private String path;private CuratorFramework curatorFramework;public MyWatcher(String path, CuratorFramework curatorFramework) {this.path = path;this.curatorFramework = curatorFramework;}@Overridepublic void process(WatchedEvent event) {System.out.println(event.toString());try {//watcher是一次性的,每次watch后需要重新设置watcherCrudExamples.watchedGetChildren(this.curatorFramework, this.getPath(), this);} catch (Exception e) {e.printStackTrace();}}public String getPath() {return path;}public CuratorFramework getCuratorFramework() {return curatorFramework;}}}

这篇关于Apache Curator简单介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1046938

相关文章

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.

python连接sqlite3简单用法完整例子

《python连接sqlite3简单用法完整例子》SQLite3是一个内置的Python模块,可以通过Python的标准库轻松地使用,无需进行额外安装和配置,:本文主要介绍python连接sqli... 目录1. 连接到数据库2. 创建游标对象3. 创建表4. 插入数据5. 查询数据6. 更新数据7. 删除

Jenkins的安装与简单配置过程

《Jenkins的安装与简单配置过程》本文简述Jenkins在CentOS7.3上安装流程,包括Java环境配置、RPM包安装、修改JENKINS_HOME路径及权限、启动服务、插件安装与系统管理设置... 目录www.chinasem.cnJenkins安装访问并配置JenkinsJenkins配置邮件通知

setsid 命令工作原理和使用案例介绍

《setsid命令工作原理和使用案例介绍》setsid命令在Linux中创建独立会话,使进程脱离终端运行,适用于守护进程和后台任务,通过重定向输出和确保权限,可有效管理长时间运行的进程,本文给大家介... 目录setsid 命令介绍和使用案例基本介绍基本语法主要特点命令参数使用案例1. 在后台运行命令2.

Python yield与yield from的简单使用方式

《Pythonyield与yieldfrom的简单使用方式》生成器通过yield定义,可在处理I/O时暂停执行并返回部分结果,待其他任务完成后继续,yieldfrom用于将一个生成器的值传递给另一... 目录python yield与yield from的使用代码结构总结Python yield与yield

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Apache Ignite缓存基本操作实例详解

《ApacheIgnite缓存基本操作实例详解》文章介绍了ApacheIgnite中IgniteCache的基本操作,涵盖缓存获取、动态创建、销毁、原子及条件更新、异步执行,强调线程池注意事项,避免... 目录一、获取缓存实例(Getting an Instance of a Cache)示例代码:二、动态

Java中使用 @Builder 注解的简单示例

《Java中使用@Builder注解的简单示例》@Builder简化构建但存在复杂性,需配合其他注解,导致可变性、抽象类型处理难题,链式编程非最佳实践,适合长期对象,避免与@Data混用,改用@G... 目录一、案例二、不足之处大多数同学使用 @Builder 无非就是为了链式编程,然而 @Builder

zookeeper端口说明及介绍

《zookeeper端口说明及介绍》:本文主要介绍zookeeper端口说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、zookeeper有三个端口(可以修改)aVNMqvZ二、3个端口的作用三、部署时注意总China编程结一、zookeeper有三个端口(可以