概念
https://www.iteye.com/blog/netcome-1474255
Zookeeper 作为一个分布式的服务框架,主要用来解决分布式集群中应用系统的一致性问题,它能提供基于类似于文件系统的目录节点树方式的数据存储,但是 Zookeeper 并不是用来专门存储数据的,它的作用主要是用来维护和监控你存储的数据的状态变化。通过监控这些数据状态的变化,从而可以达到基于数据的集群管理。Zookeeper提供一个多层级的节点命名空间(节点称为znode),每个节点都用一个以斜杠(/)分隔的路径表示,而且每个节点都有父节点(根节点除外),非常类似于文件系统。例如,/foo/doo这个表示一个znode,它的父节点为/foo,父父节点为/,而/为根节点没有父节点。与文件系统不同的是,这些节点都可以设置关联的数据,而文件系统中只有文件节点可以存放数据而目录节点不行。Zookeeper为了保证高吞吐和低延迟,在内存中维护了这个树状的目录结构,这种特性使得Zookeeper不能用于存放大量的数据,每个节点的存放数据上限为1M。
客户端的读请求可以被集群中的任意一台机器处理,如果读请求在节点上注册了监听器,这个监听器也是由所连接的zookeeper机器来处理。对于写请求,这些请求会同时发给其他zookeeper机器并且达成一致后,请求才会返回成功。因此,随着zookeeper的集群机器增多,读请求的吞吐会提高但是写请求的吞吐会下降。
有序性是zookeeper中非常重要的一个特性,所有的更新都是全局有序的,每个更新都有一个唯一的时间戳,这个时间戳称为zxid(Zookeeper Transaction Id)。而读请求只会相对于更新有序,也就是读请求的返回结果中会带有这个zookeeper最新的zxid。
性质:
- 有序节点
- 临时节点
- 事件监听
zookeeper的几种节点Znode:
- 持久节点(PERSISTENT)。节点创建后,会一直存在,不会因为创建节点的会话失效而删除。
- 持久顺序节点(PERSISTENT_SEQUENTIAL)。节点的特征是持久的,并且节点创建的过程中,Zookeeper会在其名字后自动追加一个单调递增的数字后缀,作为节点名字。
- 临时节点(EPHEMERAL)。节点创建后,会因为创建节点的会话失效而删除。临时节点不能拥有子节点。
- 临时顺序节点(EPHEMERAL_SEQUENTIAL)。节点的特征是临时的,并且节点创建的过程中,Zookeeper会在其名字后自动追加一个单调递增的数字后缀,作为节点名字。
典型应用
- 统一命名服务
- 配置管理
