Watcher详解、接口
在 ZooKeeper 中, 接口类 Watcher 用于表示一个标注你的事件处理器,其定义了事件通知相关的逻辑,包含 KeeperState 和 EventType 两个枚举类,分别代表了通知状态和事件类型,同时定义了事件的回调方法:process(WatchedEvent event)
如果Watcher
Watcher 触发条件:
增、删、改 ( 重复修改也会触发,因为他只告诉你变更了,不告诉你变更多少,需要 C 自己去拿)
abstract public void process ( WatchedEvent event )。
process() 是 Watch 接口中的回调方法。当 ZooKeeper 向客户端发送一个 Watcher 时间通知时,客户端就会对相应的 process 方法进行回调,从而实现对事件的处理。 like this:syncNodes()方法。
- private synchronized void initNodes(List<String> nodes) {
- // 根据zk节点,判断是否需要处理
- }
- private void syncNodes() {
- try {
- List<String> nodes = zookeeper.getChildren(ArbitrateConstants.NODE_NID_ROOT, new AsyncWatcher() {
- public void asyncProcess(WatchedEvent event) {
- syncNodes();// 回调方法继续关注node节点变化
- }
- });
- initNodes(nodes);
- } catch (KeeperException e) {
- syncNodes();
- } catch (InterruptedException e) {
- // ignore
- }
- }
Watcher 设置是开发中最常见的,需要搞清楚watcher的一些基本特征,对于exists、getdata、getchild对于节点的不同操作会收到不同的 watcher信息
对父节点的变更以及子节点的变更都不会触发watcher,而对watcher本身节点以及子节点的变更会触发watcher
继续。
ZooKeeper 使用 WatchedEvent 对象封装服务端事件并传递给 Watcher, 从而方便回调方法 process 对服务端事件进行处理。
WatcherEvent 实体实现了序列化接口,因此可以用于网络传输。数据结构如下。