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

相关文章

Python中win32包的安装及常见用途介绍

《Python中win32包的安装及常见用途介绍》在Windows环境下,PythonWin32模块通常随Python安装包一起安装,:本文主要介绍Python中win32包的安装及常见用途的相关... 目录前言主要组件安装方法常见用途1. 操作Windows注册表2. 操作Windows服务3. 窗口操作

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)

《MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)》掌握多表联查(INNERJOIN,LEFTJOIN,RIGHTJOIN,FULLJOIN)和子查询(标量、列、行、表子查询、相关/非相关、... 目录第一部分:多表联查 (JOIN Operations)1. 连接的类型 (JOIN Types)

SpringBoot整合Apache Flink的详细指南

《SpringBoot整合ApacheFlink的详细指南》这篇文章主要为大家详细介绍了SpringBoot整合ApacheFlink的详细过程,涵盖环境准备,依赖配置,代码实现及运行步骤,感兴趣的... 目录1. 背景与目标2. 环境准备2.1 开发工具2.2 技术版本3. 创建 Spring Boot

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存

Spring Boot 整合 Apache Flink 的详细过程

《SpringBoot整合ApacheFlink的详细过程》ApacheFlink是一个高性能的分布式流处理框架,而SpringBoot提供了快速构建企业级应用的能力,下面给大家介绍Spri... 目录Spring Boot 整合 Apache Flink 教程一、背景与目标二、环境准备三、创建项目 & 添

java中BigDecimal里面的subtract函数介绍及实现方法

《java中BigDecimal里面的subtract函数介绍及实现方法》在Java中实现减法操作需要根据数据类型选择不同方法,主要分为数值型减法和字符串减法两种场景,本文给大家介绍java中BigD... 目录Java中BigDecimal里面的subtract函数的意思?一、数值型减法(高精度计算)1.