zookeeper基本概念及3.6.0新特性

官网地址:
https://zookeeper.apache.org/doc/current/zookeeperProgrammers.html

1.数据模型

层次命名空间,像一个分布式文件系统,由节点组成形成一个树结构。每个节点是一个ZNode,可以有数据也可以有孩子节点。每个节点有一个ACL限制谁可以做什么。

2.节点类型

节点类型主要有持久节点、临时节点、持久序列节点和临时序列节点四种。
getEphemerals()可以显示一个会话的所有临时节点。
container nodeTTL node是3.6.0新增的,容器节点当最后一个孩子被删除后,他就会在不久后被服务器删除。TTL节点如果在TTL时间内没有被修改并且没有孩子节点,也会在不久后被服务器删除。

3.zookeeper中的时间

zxid(事务id),可以根据事务id的大小判断发生的先后。
version number:包括version、cversion、aversion
ticks:如果client收到的会话超时时间小于最小超时时间,实际上就是最小超时时间。

4.Stat Structure

czxid、mzxid、pzxid
ctime、mtime
version、cversion、aversion
ephemeralOnwer
dataLength、numChildren

5.会话

使用语言绑定创建一个服务器的句柄来建立与服务器的会话。
handler启动时时CONNECTING状态,链接上是CONNECTED状态。关闭时候是CLOSE状态。
创建会话需要提供一个连接字符串,逗号分隔的host:port对,每一个对应一个Zookeeper服务器。

6.Watches

getData(), getChildren(),exists()都可以选择设置watch。
3.6.0新加了Persistent, Recursive Watches,即使触发了也不会被移除并且能够对监视节点开始的所有结点进行递归。通过addWatch()设置,通过removeWatches()删除。

7.ACLs

ACLs由(scheme:expression,perms)对组成,例如(ip:19.22.0.0/16,READ)表示以19.22开头的IP都有读的权限。
ACL permissions包括CREATE、READ、WRITE、DELETE、ADMIN。
ACL schemes包括world、auth、digest、ip、x509

8.一致性保证

Sequential Consistency、Atomicity、Single System Image、Reliability、Timeliness

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Zookeeper是一个开源的分布式应用程序协调服务,它提供了一组简单的API,可以帮助开发人员实现分布式系统中的一些关键功能,如配置管理、分布式同步、命名服务、集群管理等。下面是Zookeeper的一些基本概念和功能: 1.节点:Zookeeper中的数据存储单位,它类似于文件系统中的目录或文件。每个节点都有一个路径,路径由斜杠分隔的一系列字符串组成。 2.版本:每个节点都有一个版本号,用于标识节点数据的版本。Zookeeper会为每次更新操作递增节点的版本号。 3.会话:Zookeeper客户端与服务器之间的连接称为会话。客户端可以通过会话与Zookeeper进行交互,包括创建、更新和删除节点等操作。 4.观察器:Zookeeper支持观察器机制,即客户端可以注册一个观察器来监视一个节点的变化。当节点发生变化时,Zookeeper会通知客户端。 5.集群:Zookeeper可以作为集群管理工具,用于维护各个节点之间的状态同步和故障转移。 6.分布式锁:Zookeeper提供了一种分布式锁机制,可以用于控制多个进程或线程之间的访问顺序。 7.命名服务:Zookeeper可以作为命名服务,提供一种统一的命名空间,用于管理和查找节点。 总的来说,Zookeeper提供了一种可靠的、高效的、可扩展的分布式应用程序协调服务,可以简化开发人员在分布式系统中的编程工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值