ZooKeeper数据模型/znode节点深入

1、Znode的数据模型
1.1 Znode是什么?

Znode维护了一个stat结构,这个stat包含数据变化的版本号、访问控制列表变化、还有时间戳。版本号和时间戳一起,可让Zookeeper验证缓存和协调更新。每次znode的数据发生了变化,版本号就增加。
1.2 ZooKeeper的Stat结构体

java 复制代码
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)获取修改后的子节点内容。

使用help 查看有哪些命令

java 复制代码
案例所对应的命令
(1)create /test javademo1
(2)get /test
(3)set /test javademo2
(4)get /test

2、Znode中的存在类型

2.1 PERSISTENT-持久化目录节点

客户端与zookeeper断开连接后,该节点依旧存在

java 复制代码
# create  /demo01 java01

2.2 PERSISTENT_SEQUENTIAL-持久化顺序编号目录节点

客户端与zookeeper断开连接后,该节点依旧存在,只是Zookeeper给该节点名称进行顺序编号

java 复制代码
# create -s /demo011 java011

2.3 EPHEMERAL-临时目录节点

客户端与zookeeper断开连接后,该节点被删除

java 复制代码
# create -e /demo2 java2

2.4 EPHEMERAL_SEQUENTIAL-临时顺序编号目录节点

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

java 复制代码
# create -s -e /demo03 /java03

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

相关推荐
CURRY30_HJH3 分钟前
将包含父子关系的扁平列表 List<Demo> 转换成树形结构的 List<DemoVO>,每个节点包含自己的子节点列表
linux·服务器·windows
袋鼠云数栈13 分钟前
从SQL Server到分布式大数据平台:重构企业数据架构
大数据·分布式·sql·重构·数据库架构
中云DDoS CC防护蔡蔡32 分钟前
自己的服务器被 DDOS跟CC攻击了怎么处理,如何抵御攻击?
运维·服务器·经验分享·网络安全·ddos
chian-ocean1 小时前
永不休眠:Linux 守护进程的工作原理
linux·运维·服务器
GalaxyPokemon2 小时前
LeetCode - 76. 最小覆盖子串
运维·服务器·数据结构·算法·leetcode
蜗牛编程之路2 小时前
RabbitMQ的使用--项目创建、五种工作模式、高级特性
数据库·分布式·rabbitmq
楽码2 小时前
安装和编写grpc协议文件
服务器·后端·grpc
厚衣服_32 小时前
第18篇:数据库中间件架构中的服务治理与限流熔断机制设计
数据库·中间件·架构
wanhengidc3 小时前
造成服务器宕机的原因都有哪些?
运维·服务器·网络
西北大程序猿3 小时前
服务器代码知识点补充
服务器·开发语言·网络·c++·网络协议