zoukankan      html  css  js  c++  java
  • Zookeeper如何正确设置和获取watcher

    Watcher 设置是开发中最常见的,需要搞清楚watcher的一些基本特征,对于exists、getdata、getchild对于节点的不同操作会收到不同的 watcher信息

     

    state=-112 会话超时状态
    state= -113 认证失败状态
    state=  1 连接建立中
    state= 2 (暂时不清楚如何理解这个状态,ZOO_ASSOCIATING_STATE)
    state=3 连接已建立状态
    state= 999 无连接状态


    type=1 创建节点事件
    type=2 删除节点事件
    type=3 更改节点事件
    type=4 子节点列表变化事件
    type= -1 会话session事件
    type=-2 监控被移除事件

    父节点的变更以及孙节点的变更都不会触发watcher,而对watcher本身节点以及子节点的变更会触发watcher,具体参照下表。

    操作 方法 触发watcher watcher state watcher type watcher path
    Create当前节点 getdata × × × ×
    getchildren 3 4
    exists × × × ×
    set当前节点 getdata 3 3
    getchildren × × × ×
    exists 3 3
    delete当前节点 getdata 3 2
    getchildren 3 2
    exists 3 2
    create子节点 getdata × × × ×
    getchildren 3 4
    exists × × × ×
    set子节点 getdata × × × ×
    getchildren × × × ×
    exists × × × ×
    delete子节点 getdata × × × ×
    getchildren 3 4
    exists × × × ×
    恢复连接 getdata 1 -1 ×
    getchildren 1 -1 ×
    exists 1 -1 ×
    恢复连接session未超时 getdata -112 -1 ×
    getchildren -112 -1 ×
    exists -112 -1 ×
    恢复连接session超时 getdata 3 -1 ×
    getchildren 3 -1 ×
    exists 3 -1 ×

    注:×表示否,√表示是。
    本文来自 曾经的学渣 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/qq910894904/article/details/41726279?utm_source=copy 

  • 相关阅读:
    【C++】链表回环检测
    【C++】满二叉树问题
    【C++】约瑟夫环(数组+链表)
    【C++】子序列匹配问题
    【OJ】抓牛问题
    【C++】基于邻接矩阵的图的深度优先遍历(DFS)和广度优先遍历(BFS)
    【C++】二叉树的构建、前序遍历、中序遍历
    范进中Nature——儒林外史新义
    VMware Workstation下ubuntu虚拟机无法上网连不上网络解决
    儒林外史人物——娄三、娄四公子
  • 原文地址:https://www.cnblogs.com/wangleBlogs/p/9728763.html
Copyright © 2011-2022 走看看