• 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 

  • 相关阅读:
    海量数据处理
    mysql数据导出
    手机归属地
    如何正确合理的建立MYSQL数据库索引
    Java 复杂excel报表导出
    NullpointerException真的一定要被预防?
    代码传递信息方式的探究
    ThreadLoacl的反思
    Codis分布式锁
    spring mvc:事务引起的try/catch失效
  • 原文地址:https://www.cnblogs.com/wangleBlogs/p/9728763.html
Copyright © 2020-2023  润新知