zookeeper ——watcher

1.watcher定义和说明

1.1定义

在ZooKeeper中,Watcher是一种机制,用于在节点(znode)发生特定事件时通知客户端。这种机制使得ZooKeeper能够提供一种分布式的协调和同步服务,确保多个客户端能够及时响应数据变化。

1.2特性

在这里插入图片描述

1.3watcher的通知状态Watcher.Event.KeeperState

在这里插入图片描述

1.4watcher的事件类型Event.EventType

在这里插入图片描述

1.5基本流程

  1. 客户端注册Watcher: 客户端通过ZooKeeper API(如getData、exists、getChildren等)向服务器注册Watcher。
    注册时,客户端会将Watcher对象存储在客户端的WatchManager中。
    Watcher是一个接口,客户端需要实现其中的process(WatchedEvent event)方法来定义事件处理逻辑。
  1. 服务器处理Watcher注册: 服务器接收到客户端的注册请求后,会将Watcher对象与对应的znode(ZooKeeper中的数据节点)绑定,并记录在内存中。
    服务器不会持久化存储这些Watcher,因此一旦服务器重启,所有注册的Watcher都将失效。
  1. 事件触发与通知: 当znode的状态发生变化(如数据变更、子节点变更等)时,服务器会触发与该znode绑定的Watcher。 服务器将包含事件信息(如事件类型、znode路径等)的WatchedEvent对象封装成通知,并发送给客户端。
  1. 客户端接收并处理通知: 客户端的EventThread线程负责接收来自服务器的Watcher事件通知。 EventThread从WatchManager中取出对应的Watcher对象,并调用其process(WatchedEvent
    event)方法来处理事件。 客户端根据事件类型执行相应的逻辑,如重新获取znode数据、更新本地状态等。
ZooKeeperWatcher是一种机制,主要由客户端线程、客户端WatchManager和ZooKeeper服务器三部分组成。Watcher的作用是监听ZooKeeper上的数据节点的变化,并在数据发生变化时触发相关的事件。具体来说,当数据节点被修改、删除或新节点被创建时,Watcher会通知客户端。这样,客户端就可以及时获取最新的数据状态,做出相应的处理。 Watcher机制的实现是通过在ZooKeeper客户端注册Watcher对象,该对象包含了要监听的数据节点以及相应的事件处理逻辑。当节点的状态发生变化时,ZooKeeper服务器会通知所有注册了Watcher的客户端。客户端接收到通知后,会根据注册时设定的逻辑进行相应的处理,例如更新本地缓存、重新获取数据等。 需要注意的是,ZooKeeperWatcher是一次性的,即触发一次后就会失效。因此,在每次接收到Watcher通知后,客户端需要重新注册Watcher来实现持续的监视。 总结起来,ZooKeeperWatcher是一种用于监听ZooKeeper上数据节点变化的机制,可以帮助客户端实时获取数据状态的变化,并进行相应的处理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Zookeeper Watcher机制](https://blog.csdn.net/TABE_/article/details/120832960)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [zookeeper-watcher-demo:动物园管理员 wather 演示](https://download.csdn.net/download/weixin_42135753/19559786)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

无奈ieq

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

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

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

打赏作者

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

抵扣说明:

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

余额充值