Curator实现zookeeper的节点监听详解
更新时间:2023年12月18日 10:23:13 作者:暴躁的程序猿啊
这篇文章主要介绍了Curator实现zookeeper的节点监听详解,Curtor框架中一共有三个实现监听的方式,一种是NodeCache监听指定节点,一种是pathChildrenCache监听子节点,一种是TreeCache可以监控所有节点 相当于以上两种的合集,需要的朋友可以参考下
Curator实现zookeeper的节点监听
Curtor框架中一共有三个实现监听的方式 一种是NodeCache监听指定节点 一种是pathChildrenCache监听子节点 一种是TreeCache可以监控所有节点 相当于以上两种的合集
引入依赖
<dependency> <groupId>org.apache.curator</groupId> <artifactId>curator-framework</artifactId> <version>4.3.0</version> </dependency> <dependency> <groupId>org.apache.curator</groupId> <artifactId>curator-client</artifactId> <version>4.3.0</version> </dependency> <dependency> <groupId>org.apache.curator</groupId> <artifactId>curator-recipes</artifactId> <version>4.3.0</version> </dependency>
创建一个测试类 连接好客户端
public class CuratorTest { private CuratorFramework curatorFramework; @Before public void testCreate() { ExponentialBackoffRetry retry = new ExponentialBackoffRetry(2, 10); curatorFramework = CuratorFrameworkFactory.builder() .connectString("127.0.0.1:2181") .connectionTimeoutMs(60 * 1000) .sessionTimeoutMs(15 * 10000) .retryPolicy(retry).build(); curatorFramework.start(); } @After public void close() { if (curatorFramework != null) { curatorFramework.close(); } } }
Watch监听之NodeCache
监听一个指定节点
@Test public void testUpdate() throws Exception { //监听一个节点 NodeCache nodeCache = new NodeCache(curatorFramework,"/dongwuyuan"); //注册监听 nodeCache.getListenable().addListener(new NodeCacheListener() { @Override public void nodeChanged() throws Exception { System.out.println("节点变化了!!!!"); } }); //开启监听 参数 如果设置为true 则开启监听时加载缓存数据 nodeCache.start(true); while (true){ } }
set /dongwuyuan "laohu"
Watch监听之PathChildrenCache
监听子节点的变化
@Test public void testPathChildrenCache() throws Exception { // 参数 客户端,路径 ,缓存数据,是否压缩,线程池 PathChildrenCache pathChildrenCache = new PathChildrenCache(curatorFramework,"/dongwuyuan",true); //绑定监听器 pathChildrenCache.getListenable().addListener(new PathChildrenCacheListener() { @Override public void childEvent(CuratorFramework curatorFramework, PathChildrenCacheEvent pathChildrenCacheEvent) throws Exception { System.out.println("子节点变化了"); System.out.println(pathChildrenCacheEvent); //监听子节点的变更,并且拿到变更后的数据 PathChildrenCacheEvent.Type type = pathChildrenCacheEvent.getType(); //判断类型是否是update if(type.equals(PathChildrenCacheEvent.Type.CHILD_UPDATED)){ //拿到数据 byte[] data = pathChildrenCacheEvent.getData().getData(); System.out.println(data); } } }); //开启监听 pathChildrenCache.start(); while (true){ } }
watch监听之TreeCache
/** * TreeCache:监听节点自己和所有子节点们 */ @Test public void testTreeCache(){ //1.创建监听器 TreeCache treeCache = new TreeCache(curatorFramework, "/dongwuyuan"); //2.注册监听 treeCache.getListenable().addListener(new TreeCacheListener() { @Override public void childEvent(CuratorFramework client, TreeCacheEvent event) throws Exception { System.out.println("节点变化了"); System.out.println(event); } }); //开启监听 try { treeCache.start(); while (true){ } } catch (Exception e) { e.printStackTrace(); } }
[zk: localhost:2181(CONNECTED) 13] delete /dongwuyuan/node1
[zk: localhost:2181(CONNECTED) 15] set /dongwuyuan/node2 "shizi"
完整代码
public class CuratorTest { private CuratorFramework curatorFramework; @Before public void testCreate() { ExponentialBackoffRetry retry = new ExponentialBackoffRetry(2, 10); curatorFramework = CuratorFrameworkFactory.builder() .connectString("127.0.0.1:2181") .connectionTimeoutMs(60 * 1000) .sessionTimeoutMs(15 * 10000) .retryPolicy(retry).build(); curatorFramework.start(); } @Test public void testUpdate() throws Exception { //监听一个节点 NodeCache nodeCache = new NodeCache(curatorFramework,"/dongwuyuan"); //注册监听 nodeCache.getListenable().addListener(new NodeCacheListener() { @Override public void nodeChanged() throws Exception { System.out.println("节点变化了!!!!"); } }); //开启监听 参数 如果设置为true 则开启监听时加载缓存数据 nodeCache.start(true); while (true){ } } @Test public void testPathChildrenCache() throws Exception { // 参数 客户端,路径 ,缓存数据,是否压缩,线程池 PathChildrenCache pathChildrenCache = new PathChildrenCache(curatorFramework,"/dongwuyuan",true); //绑定监听器 pathChildrenCache.getListenable().addListener(new PathChildrenCacheListener() { @Override public void childEvent(CuratorFramework curatorFramework, PathChildrenCacheEvent pathChildrenCacheEvent) throws Exception { System.out.println("子节点变化了"); System.out.println(pathChildrenCacheEvent); //监听子节点的变更,并且拿到变更后的数据 PathChildrenCacheEvent.Type type = pathChildrenCacheEvent.getType(); //判断类型是否是update if(type.equals(PathChildrenCacheEvent.Type.CHILD_UPDATED)){ //拿到数据 byte[] data = pathChildrenCacheEvent.getData().getData(); System.out.println(data); } } }); //开启监听 pathChildrenCache.start(); while (true){ } } /** * TreeCache:监听节点自己和所有子节点们 */ @Test public void testTreeCache(){ //1.创建监听器 TreeCache treeCache = new TreeCache(curatorFramework, "/dongwuyuan"); //2.注册监听 treeCache.getListenable().addListener(new TreeCacheListener() { @Override public void childEvent(CuratorFramework client, TreeCacheEvent event) throws Exception { System.out.println("节点变化了"); System.out.println(event); } }); //开启监听 try { treeCache.start(); while (true){ } } catch (Exception e) { e.printStackTrace(); } } @After public void close() { if (curatorFramework != null) { curatorFramework.close(); } } }
到此这篇关于Curator实现zookeeper的节点监听详解的文章就介绍到这了,更多相关zookeeper节点监听内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
SpringBoot使用@ControllerAdvice全局异常处理
这篇文章主要介绍了SpringBoot使用@ControllerAdvice全局异常处理,异常处理是非常重要的一部分,它可以帮助我们捕获并处理应用程序中出现的异常情况,提高应用程序的健壮性和可靠性,需要的朋友可以参考下2023-07-07Java 最重要布局管理器GridBagLayout的使用方法
GridBagLayout是java里面最重要的布局管理器之一,可以做出很复杂的布局,可以说GridBagLayout是必须要学好的的,需要的朋友可以了解下2012-12-12SpringBoot使用slf4j日志并输出到文件中的操作方法
这篇文章主要介绍了SpringBoot使用slf4j日志并输出到文件中,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-08-08
最新评论