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

相关文章

Java中 instanceof 的用法详细介绍

《Java中instanceof的用法详细介绍》在Java中,instanceof是一个二元运算符(类型比较操作符),用于检查一个对象是否是某个特定类、接口的实例,或者是否是其子类的实例,这篇文章... 目录引言基本语法基本作用1. 检查对象是否是指定类的实例2. 检查对象是否是子类的实例3. 检查对象是否

什么是ReFS 文件系统? ntfs和refs的优缺点区别介绍

《什么是ReFS文件系统?ntfs和refs的优缺点区别介绍》最近有用户在Win11Insider的安装界面中发现,可以使用ReFS来格式化硬盘,这是不是意味着,ReFS有望在未来成为W... 数十年以来,Windows 系统一直将 NTFS 作为「内置硬盘」的默认文件系统。不过近些年来,微软还在研发一款名

解决Maven项目报错:failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.13.0的问题

《解决Maven项目报错:failedtoexecutegoalorg.apache.maven.plugins:maven-compiler-plugin:3.13.0的问题》这篇文章主要介... 目录Maven项目报错:failed to execute goal org.apache.maven.pl

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命

深入理解Apache Kafka(分布式流处理平台)

《深入理解ApacheKafka(分布式流处理平台)》ApacheKafka作为现代分布式系统中的核心中间件,为构建高吞吐量、低延迟的数据管道提供了强大支持,本文将深入探讨Kafka的核心概念、架构... 目录引言一、Apache Kafka概述1.1 什么是Kafka?1.2 Kafka的核心概念二、Ka

Pytest多环境切换的常见方法介绍

《Pytest多环境切换的常见方法介绍》Pytest作为自动化测试的主力框架,如何实现本地、测试、预发、生产环境的灵活切换,本文总结了通过pytest框架实现自由环境切换的几种方法,大家可以根据需要进... 目录1.pytest-base-url2.hooks函数3.yml和fixture结论你是否也遇到过

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3