zookeeper的watch机制详细讲解

本文详细介绍了Zookeeper的Watch机制,包括其作为数据变更触发器的功能,以及客户端如何通过zkCli和Curator进行watch操作。在zkCli中,get-w用于监听节点数据变化,ls-w监听目录的创建和删除,而ls-R-w则监听目录及其子目录的变化。在Curator客户端中,NodeCache监听单个节点变化,PathChildrenCache则用于监听目录变化。
摘要由CSDN通过智能技术生成

一、Watch机制介绍

我们可以把 Watch 理解成是注册在特定 Znode 上的触发器。当这个 Znode 发⽣改变,也就是调⽤了 create , delete , setData ⽅法的时候,将会触发 Znode 上注册的对应事件,请求 Watch 的客户端会接收到异步通知。

具体交互过程如下:

  • 客户端调⽤ getData ⽅法的时候, watch 参数设置为 true 。服务端接到请求,返回节点数据,并 且在对应的哈希表⾥插⼊被 Watch的 Znode 路径。
  • 当被 Watch 的 Znode 已删除,服务端会查找哈希表,找到该 Znode 对应的所有
    Watcher,异步通知客户端,并且删除哈希表中对应的 Key-Value。

这里的服务端指的是zk的服务端。
在这里插入图片描述
客户端使⽤了NIO通信模式监听服务端的调⽤。

二、zkCli客户端使⽤watch

zkCli客户端常用命令详解:

https://blog.csdn.net/weixin_43888891/article/details/125400879

  • create /test:创建test节点
  • set /test aaa:给test节点赋值aaa数据
  • get -w /test:⼀次性监听节点,注意这里是监听的数据变化,假如test子节点的数据发生变化也是收不到监听消息的(假如在监听节点下创建和删除子节点这些都是监听不到的,但是删除监听的节点是可以监听到的)
  • ls -w /test :监听⽬录,创建和删除⼦节点会收到通知。⼦节点中新增节点不会收到通知
  • ls -R -w /test :对于⼦节点中⼦节点的变化,但内容的变化不会收到通知

2.1、get -w命令详解

创建一个节点后,然后通过 get -w /test监听节点,然后使用另外一个客户端对该节点进行了赋值,这时候可以看到收到的监听消息。

在这里插入图片描述
监听到后并不是监听到修改后新的值,而是类似于一个消息,意思是告诉他节点发生变化了。这时候可以通过get /test命令来获取节点被修改后的值。
在这里插入图片描述
再次使用另一个客户端set了一下值,并没有监听到消息,因为 get -w /test是⼀次性监听节点。
在这里插入图片描述
假如想一直监听的话,可以在收到监听消息后,立马再执行 get -w /test命令。
在这里插入图片描述
删除节点是可以监听到的,监听到的消息事件类型和数据修改是不一样的。
在这里插入图片描述

2.2、ls -w命令详解

ls -w监听当前节点的创建和删除
在这里插入图片描述
又使用命令开启了监听,然后在刚刚创建的sub1节点下又创建了一个子节点,这时候收不到监听的。
在这里插入图片描述

2.3、ls -R -w命令详解

在这里插入图片描述

三、curator客户端使⽤watch

springboot整合curator客户端:https://blog.csdn.net/weixin_43888891/article/details/125442668

我直接是基于上一篇文章当中的项目进行watch练习!

@Test
/**
  * 监听test节点
  *
  * @throws Exception
  */
 @Test
 public void addNodeListener() throws Exception {

     NodeCache nodeCache = new NodeCache(curatorFramework, "/test");
     nodeCache.getListenable().addListener(new NodeCacheListener() {
         @Override
         public void nodeChanged() throws Exception {
             log.info("{} path nodeChanged: ", "/test");
             printNodeData();
         }
     });
     nodeCache.start();
     // 阻塞线程
     System.in.read();
 }

 /**
  * 获取test节点数据并打印
  *
  * @throws Exception
  */
 public void printNodeData() throws Exception {
     byte[] bytes = curatorFramework.getData().forPath("/test");
     log.info("data: {}", new String(bytes));
 }
 
/**
 * 监听test节点目录变化(类似于ls -w /test命令)
 *
 * @throws Exception
 */
@Test
public void addPathChildrenCacheListener() throws Exception {

    PathChildrenCache watcher = new PathChildrenCache(curatorFramework, "/test", true);
    watcher.getListenable().addListener(new PathChildrenCacheListener() {
        public void childEvent(CuratorFramework curatorFramework, PathChildrenCacheEvent pathChildrenCacheEvent) throws Exception {
            System.out.println(pathChildrenCacheEvent);
        }
    });
    watcher.start(PathChildrenCache.StartMode.BUILD_INITIAL_CACHE);
    // 阻塞线程
    System.in.read();
}

在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

怪 咖@

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值