Zookeeper客户端使用(使用Curator)
Zookeeper客户端(使用Curator)
三、使用curator客户端
在pom.xml中加入依赖
<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.11.0</version>
</dependency>
直接上代码:
/**
* Project Name:mk-project <br>
* Package Name:com.suns.zookeeper.curator <br>
*
* @author mk <br>
* Date:2018-10-31 14:03 <br>
*/ package com.suns.zookeeper.curator; import org.apache.curator.RetryPolicy;
import org.apache.curator.framework.CuratorFramework;
import org.apache.curator.framework.CuratorFrameworkFactory;
import org.apache.curator.framework.recipes.cache.*;
import org.apache.curator.retry.ExponentialBackoffRetry;
import org.apache.zookeeper.CreateMode;
import org.apache.zookeeper.data.Stat; import java.util.concurrent.TimeUnit; /**
* curator客户端使用
*
* 和原生zookeeper优点:
* 1.使用api更方便,功能更丰富
* 2.监听节点数据改变或者子节点变化,只需要订阅一次,便可以一直使用。而原生zookeeper的监听是一次性的,需要重复注册。
* 3.链式编程
*
* Curator包含了几个包:
* curator-framework:对zookeeper的底层api的一些封装
* curator-client:提供一些客户端的操作,例如重试策略等
* curator-recipes:封装了一些高级特性,如:Cache事件监听、选举、分布式锁、分布式计数器、分布式Barrier等
* ClassName: ZkCuratorTest <br>
* Description: <br>
* @author mk
* @Date 2018-10-31 14:03 <br>
* @version
*/
public class ZkCuratorTest { public static final String connect = "127.0.0.1:2181";
private static CuratorFramework curatorFramework = null;
private static String nodePath = "/curator1";
private static String nodeChildPath = "/curator1/n1/n11/n111/n1111"; public static void main(String[] args) throws Exception { //初始化
init(connect,5000); //监听节点数据改变或者子节点变化,只需要订阅一次,便可以一直使用。而原生zookeeper的监听是一次性的,需要重复注册。
listener(nodePath); //新增
create(nodePath,"n1");
//递归新增
createRecursion(nodeChildPath,"n1"); //查询
query(nodePath); TimeUnit.SECONDS.sleep(2); //修改
update(nodePath,"n11"); //单个节点删除
// delete(nodePath);
//递归删除
deleteRecursion(nodePath); } private static void deleteRecursion(String path) throws Exception {
Void aVoid = curatorFramework.delete().deletingChildrenIfNeeded().forPath(path);
System.out.println("delete:"+"["+path+"],result:"+aVoid);
} private static void delete(String path) throws Exception {
Void aVoid = curatorFramework.delete().forPath(path);
System.out.println("delete:"+"["+path+"],result:"+aVoid); } private static void update(String path, String data) throws Exception {
Stat stat = curatorFramework.setData().forPath(path, data.getBytes());
System.out.println("setData:"+"["+path+"],stat:"+stat); } private static void query(String path) throws Exception {
byte[] bytes = curatorFramework.getData().forPath(path);
System.out.println("query:"+"["+path+"],result:"+new String(bytes)); } private static void createRecursion(String path,String data) throws Exception {
String result = curatorFramework.create().creatingParentContainersIfNeeded().withMode(CreateMode.PERSISTENT).forPath(path, data.getBytes());
System.out.println("create:"+"["+path+"-->"+data+"],result:"+result); } private static void create(String path, String data) throws Exception {
// Stat stat = curatorFramework.checkExists().forPath(path);
// if(null != stat){
// System.out.println("节点["+path+"]已存在,不能新增");
// return;
// }
String result = curatorFramework.create().creatingParentsIfNeeded().withMode(CreateMode.PERSISTENT).forPath(path, data.getBytes());
System.out.println("create:"+"["+path+"-->"+data+"],result:"+result);
} private static void listener(String path) throws Exception { //监听节点内容改变
final NodeCache nodeCache = new NodeCache(curatorFramework, path);
nodeCache.start();
/*nodeCache.getListenable().addListener(new NodeCacheListener() {
@Override
public void nodeChanged() throws Exception {
System.out.println("节点内容发生变化----->"+nodeCache.getCurrentData());
}
});*/ //使用lambda表达式-jdk1.8以上
nodeCache.getListenable().addListener(()->{System.out.println("节点内容发生变化----->"+nodeCache.getCurrentData());}); //监听子节点改变
final PathChildrenCache pathChildrenCache = new PathChildrenCache(curatorFramework, path, true);
pathChildrenCache.start(PathChildrenCache.StartMode.POST_INITIALIZED_EVENT);
/* pathChildrenCache.getListenable().addListener(new PathChildrenCacheListener() {
@Override
public void childEvent(CuratorFramework curatorFramework, PathChildrenCacheEvent pathChildrenCacheEvent) throws Exception {
switch (pathChildrenCacheEvent.getType() ){
case CHILD_ADDED:
System.out.println("新增子节点"+pathChildrenCache.getCurrentData());
break;
case CHILD_UPDATED:
System.out.println("更新子节点"+pathChildrenCache.getCurrentData());
break;
case CHILD_REMOVED:
System.out.println("删除子节点"+pathChildrenCache.getCurrentData());
break;
default:break;
}
}
});*/
//使用lambda表达式-jdk1.8以上
pathChildrenCache.getListenable().addListener((curatorFramework,pathChildrenCacheEvent)->
{switch (pathChildrenCacheEvent.getType() ){
case CHILD_ADDED:
System.out.println("新增子节点"+pathChildrenCache.getCurrentData());
break;
case CHILD_UPDATED:
System.out.println("更新子节点"+pathChildrenCache.getCurrentData());
break;
case CHILD_REMOVED:
System.out.println("删除子节点"+pathChildrenCache.getCurrentData());
break;
default:break;
}}); } private static void init(String connect, int sessionTimeout) {
RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000,3);//重试策略,初始等待1s,重试3次
//通过工厂获得CuratorFramework
curatorFramework = CuratorFrameworkFactory.builder()
.connectString(connect).connectionTimeoutMs(sessionTimeout).retryPolicy(retryPolicy).build();
curatorFramework.start();//开启连接
System.out.println("curatorFramework start :" +connect);
} } 运行截图:
Zookeeper客户端使用(使用Curator)的更多相关文章
- zookeeper客户端使用第三方(Curator)封装的Api操作节点
1.为什么使用Curator? Curator本身是Netflix公司开源的zookeeper客户端: Curator 提供了各种应用场景的实现封装: curator-framework 提供了f ...
- Zookeeper客户端Curator基本API
在使用zookeper的时候一般不使用原生的API,Curator,解决了很多Zookeeper客户端非常底层的细节开发工作,包括连接重连.反复注册Watcher和NodeExistsExceptio ...
- Zookeeper客户端Curator的使用,简单高效
Curator是Netflix公司开源的一个Zookeeper客户端,与Zookeeper提供的原生客户端相比,Curator的抽象层次更高,简化了Zookeeper客户端的开发量. 1.引入依赖: ...
- Zookeeper客户端Curator使用详解
Zookeeper客户端Curator使用详解 前提 最近刚好用到了zookeeper,做了一个基于SpringBoot.Curator.Bootstrap写了一个可视化的Web应用: zookeep ...
- 7.5 zookeeper客户端curator的基本使用 + zkui
使用zookeeper原生API实现一些复杂的东西比较麻烦.所以,出现了两款比较好的开源客户端,对zookeeper的原生API进行了包装:zkClient和curator.后者是Netflix出版的 ...
- zookeeper(六):Zookeeper客户端Curator的API使用详解
简介 Curator是Netflix公司开源的一套zookeeper客户端框架,解决了很多Zookeeper客户端非常底层的细节开发工作,包括连接重连.反复注册Watcher和NodeExistsEx ...
- 转:Zookeeper客户端Curator使用详解
原文:https://www.jianshu.com/p/70151fc0ef5d Zookeeper客户端Curator使用详解 前提 最近刚好用到了zookeeper,做了一个基于SpringBo ...
- Zookeeper客户端Apache Curator
本文不对Zookeeper进行介绍,主要介绍Curator怎么操作Zookeeper. Apache Curator是Apache ZooKeeper的Java / JVM客户端库,Apache Zo ...
- Zookeeper系列三:Zookeeper客户端的使用(Zookeeper原生API如何进行调用、ZKClient、Curator)和Zookeeper会话
一.Zookeeper原生API如何进行调用 准备工作: 首先在新建一个maven项目ZK-Demo,然后在pom.xml里面引入zk的依赖 <dependency> <groupI ...
随机推荐
- Python学习小技巧之列表项的排序
Python学习小技巧之列表项的排序 本文介绍的是关于Python列表项排序的相关内容,分享出来供大家参考学习,下面来看看详细的介绍: 典型代码1: data_list = [6, 9, 1, ...
- eclipse下写html
3.创建静态web工程 打开eclipse,选择file,new project 或者 new other...,选择web项中的static web project ,next. 输入你的项目名,如 ...
- .net代码混淆 .NET Reactor 研究 脚本一键混淆一键发布
.net代码混淆 .NET Reactor 研究 为什么要混淆? .net比较适合快速开发桌面型应用,但缺点是发布出来的文件是可以反编译的,有时候为了客户的安全,我们的代码或者我们的逻辑不想让别人知道 ...
- easyui datagrid checkbox复选框取消单击选中事件、初始全选全不选等问题解决
系统业务需要,导入的列表数据默认全部选中,且不可取消选中行.全部店铺优惠券发放过后导入的数据全部清空.如图所示: 一.初始化页面默认全部选中“selectAll”,全部不选中“unselectAll” ...
- SQL 批量添加的语法
.--添加一条记录 . insert into tableName(col1,col2,col3) values (val1,val2,val3) .--添加多条记录 . insert into ta ...
- 牛客小白月赛12-C(欧拉筛解积性方程)
题目链接:https://ac.nowcoder.com/acm/contest/392/C 题意:给定n,求: 思路:令res[i]=iN (%MOD),因为xn是一个积性函数,即(x*y)n=x ...
- SpreadJS与Vue集成,苏宁集团『极客办公』系统开发案例
“造极”如今已成为苏宁集团的年度核心关键词.“造极”在具体工作上的体现,代表着苏宁不断追求极致的工匠精神,即对待每一个环节,都要严格要求.精益求精.“极客办公”系统,正是在这种环境下应运而生.本期公开 ...
- 使用javascript完成一个简单工厂设计模式。
在JS中创建对象会习惯的使用new关键字和类构造函数(也是可以用对象字面量). 工厂模式就是一种有助于消除两个类依赖性的模式. 工厂模式分为简单工厂模式和复杂工厂模式,这篇主要讲简单工厂模式. 简单工 ...
- pyhton sort()无返回值
li3=['] li4=li3.sort()#sort是没有返回值得,打印的是none,对列表进行升序排列 print(li4) print(li3) 输出结果是None['123', '123', ...
- 用Python快速找到出现次数最多的数据
给你一个文件,每行一个iip?