• ZooKeeper数据模型/znode节点深入


    1、Znode的数据模型
    1.1 Znode是什么?
    Znode维护了一个stat结构,这个stat包含数据变化的版本号、访问控制列表变化、还有时间戳。版本号和时间戳一起,可让Zookeeper验证缓存和协调更新。每次znode的数据发生了变化,版本号就增加。
    1.2 ZooKeeper的Stat结构体
    在这里插入图片描述

    czxid- 引起这个znode创建的zxid,创建节点的事务的zxid(ZooKeeper Transaction Id)
    每次修改ZooKeeper状态都会收到一个zxid形式的时间戳,也就是ZooKeeper事务ID。
    事务ID是ZooKeeper中所有修改总的次序。每个修改都有唯一的zxid,如果zxid1小于zxid2,那么zxid1在zxid2之前发生。
    ctime - znode被创建的毫秒数(1970年开始)
    mzxid - znode最后更新的zxid
    mtime - znode最后修改的毫秒数(1970年开始)
    pZxid-znode最后更新的子节点zxid
    cversion - znode子节点变化号,znode子节点修改次数
    dataversion - znode数据变化号
    aclVersion - znode访问控制列表的变化号
    ephemeralOwner- 如果是临时节点,这个是znode拥有者的session id。如果不是临时节点则是0x0。
    dataLength- znode的数据长度
    numChildren - znode子节点数量
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    例:
    (1)创建新的子节点,并添加数据。
    (2)获取新创建的子节点。
    (3)修改创建的子节点内容。
    (4)获取修改后的子节点内容。
    使用help 查看有哪些命令
    在这里插入图片描述

    案例所对应的命令
    (1)create /test javademo1
    (2)get /test
    (3)set /test javademo2
    (4)get /test
    
    • 1
    • 2
    • 3
    • 4
    • 5

    2、Znode中的存在类型

    2.1 PERSISTENT-持久化目录节点
    客户端与zookeeper断开连接后,该节点依旧存在

    # create  /demo01 java01
    
    • 1

    2.2 PERSISTENT_SEQUENTIAL-持久化顺序编号目录节点
    客户端与zookeeper断开连接后,该节点依旧存在,只是Zookeeper给该节点名称进行顺序编号

    # create -s /demo011 java011
    
    • 1

    2.3 EPHEMERAL-临时目录节点
    客户端与zookeeper断开连接后,该节点被删除

    # create -e /demo2 java2
    
    • 1

    2.4 EPHEMERAL_SEQUENTIAL-临时顺序编号目录节点
    客户端与zookeeper断开连接后,该节点被删除,只是Zookeeper给该节点名称进行顺序编号

    # create -s -e /demo03 /java03
    
    • 1

    默认情况下是持久化节点!

  • 相关阅读:
    一天获4奖!大势智慧荣获2023测绘科学技术奖一等奖、地理信息科技进步奖一等奖、测绘科技创新优秀单位、地理信息产业最具成长性企业
    章节十三:协程实践
    Apifox : 不仅是Api调试工具,更是开发团队的协作神器
    python基础语法二(函数、列表)
    Unity --- UI图像,锚点与轴心点
    Set接口的实现类---HashSet
    Thread.sleep和TimeUnit.SECONDS.sleep的区别
    「Django秘境探险:揭开Web开发的神秘面纱」
    史上最全架构师知识图谱(纯干货)
    Kube-OVN-安装配置参数选项
  • 原文地址:https://blog.csdn.net/qq_39311377/article/details/132524944