1、Zookeeper 下 Server工作状态
每个Server在工作过程中有三种状态:
LOOKING:当前Server不知道leader是谁,正在搜寻
LEADING:当前Server即为选举出来的leader
FOLLOWING:leader已经选举出来,当前Server与之同步
2、ZooKeeper定义了几种权限?
1、 CREATE
2、 READ
3、 WRITE
4、 DELETE
5、 ADMIN
3、ZooKeeper用推/拉模式?
推拉结合
4、客户端如何获取配置信息?
启动时主动到服务端拉取信息,同时,在制定节点注册Watcher监听。一旦有配置变化,服务端就会实时通知订阅它的所有客户端。
5、会话管理
分桶策略:将类似的会话放在同一区块中进行管理,以便于 Zookeeper 对会话进行不同区块的隔离处理以及同一区块的统一处理。
分配原则:每个会话的“下次超时时间点”(ExpirationTime)
计算公式:
ExpirationTime\_ = currentTime + sessionTimeout
ExpirationTime = (ExpirationTime\_ / ExpirationInrerval + 1) \*
ExpirationInterval , ExpirationInterval 是指 Zookeeper 会话超时检查时间间隔,默认 tickTime
6、四种类型的数据节点 Znode
1、 PERSISTENT-持久节点 除非手动删除,否则节点一直存在于 Zookeeper 上
2、 EPHEMERAL-临时节点 临时节点的生命周期与客户端会话绑定,一旦客户端会话失效(客户端与zookeeper 连接断开不一定会话失效),那么这个客户端创建的所有临时节点都会被移除。
3、 PERSISTENT_SEQUENTIAL-持久顺序节点 基本特性同持久节点,只是增加了顺序属性,节点名后边会追加一个由父节点维护的自增整型数字。
4、 EPHEMERAL_SEQUENTIAL-临时顺序节点 基本特性同临时节点,增加了顺序属性,节点名后边会追加一个由父节点维护的自增整型数字。
7、zookeeper是如何保证事务的顺序一致性的?
zookeeper采用了递增的事务Id来标识,所有的proposal(提议)都在被提出的时候加上了zxid,zxid实际上是一个64位的数字,高32位是epoch(时期; 纪元; 世; 新时代)用来标识leader是否发生改变,如果有新的leader产生出来,epoch会自增,低32位用来递增计数。当新产生proposal的时候,会依据数据库的两阶段过程,首先会向其他的server发出事务执行请求,如果超过半数的机器都能执行并且能够成功,那么就会开始执行。
8、发现?
Follower把自己最后的接受事务的Proposal值(CEPOCH(F.p)发送给Leader。
当收到过半Follower的消息后,Leader生成NEWEPOCH(e')给这些过半的Follower。
tips: e' = Max((CEPOCH(F.p)) + 1
Follower收到消息后,如果自己值小于e',则同步e'的值,同时向Leader发Ack消息。
9、客户端注册Watcher实现
1、 调用getData()/getChildren()/exist()三个API,传入Watcher对象
2、 标记请求request,封装Watcher到WatchRegistration
3、 封装成Packet对象,发服务端发送request
4、 收到服务端响应后,将Watcher注册到ZKWatcherManager中进行管理
5、 请求返回,完成注册。
10、Zookeeper文件系统
Zookeeper提供一个多层级的节点命名空间(节点称为znode)。与文件系统不同的是,这些节点都可以设置关联的数据,而文件系统中只有文件节点可以存放数据而目录节点不行。Zookeeper为了保证高吞吐和低延迟,在内存中维护了这个树状的目录结构,这种特性使得Zookeeper不能用于存放大量的数据,每个节点的存放数据上限为1M。