汇总智一面Java刷题,问答题之ZooKeeper

ZooKeeper 是一个开放源码的分布式协调服务,它是集群的管理者,监视着集群中各个节点的状态根据节点提交的反馈进行下一步合理操作。

————智一面在线测评:Java实习/初级


1、ZooKeeper 提供了什么?

1、文件系统

2、通知机制

2、 Zookeeper 文件系统

Zookeeper 提供一个多层级的节点命名空间(节点称为 znode)。与文件系统不同的是,这些节点都可以设置关联的数据,而文件系统中只有文件节点可以存放数据而目录节点不行。

Zookeeper为了保证高吞吐和低延迟,在内存中维护了这个树状的目录结构,这种特性使得

Zookeeper 不能用于存放大量的数据,每个节点的存放数据上限为1M

3、ZAB 协议?

ZAB 协议是为分布式协调服务 Zookeeper 专门设计的一种支持崩溃恢复的原子广播协议。

ZAB 协议包括两种基本的模式:崩溃恢复和消息广播

当整个zookeeper 集群刚刚启动或者 Leader 服务器宕机、重启或者网络故障导致不存在过半的服务器与 Leader 服务器保持正常通信时,所有进程(服务器)进入崩溃恢复模式,首先选举产生新的 Leader 服务器,然后集群中 Follower 服务器开始与新的 Leader 服务器进行数据同步,当集群中超过半数机器与该 Leader服务器完成数据同步之后,退出恢复模式进入消息广播模式,Leader 服务器开始接收客户端的事务请求生成事物提案来进行事务请求处理。

4Zookeeper 下 Server 工作状态

服务器具有四种状态,分别是LOOKING、FOLLOWING、LEADING、OBSERVING。

l LOOKING:寻找Leader 状态。当服务器处于该状态时,它会认为当前集群中没有 Leader,因此需要进入Leader 选举状态。

l FOLLOWING:跟随者状态。表明当前服务器角色是Follower。

l LEADING:领导者状态。表明当前服务器角色是Leader。

l OBSERVING:观察者状态。表明当前服务器角色是Observer。

5、zookeeper 负载均衡和 nginx 负载均衡区别

zk 的负载均衡是可以调控,nginx 只是能调权重,其他需要可控的都需要自己写插件;但是nginx 的吞吐量比 zk 大很多,应该说按业务选择用哪种方式。

6、Zookeeper 有哪几种几种部署模式?

部署模式:单机模式、伪集群模式、集群模式。

7、集群最少要几台机器,集群规则是怎样的?

集群规则为2N+1 台,N>0,即 3 台。

8、Zookeeper 的 java 客户端都有哪些?

java 客户端:zk 自带的 zkclient 及 Apache 开源的 Curator。

9、说几个zookeeper 常用的命令。

常用命令:ls get set create delete 等。



10、Zookeeper 的典型应用场景

Zookeeper 是一个典型的发布/订阅模式的分布式数据管理与协调框架,开发人员可以使用它来进行分布式数据的发布和订阅。

通过对Zookeeper 中丰富的数据节点进行交叉使用,配合 Watcher 事件通知机制,可以非常方便的构建一系列分布式应用中年都会涉及的核心功能,如:

l 数据发布/订阅

l 负载均衡

l 命名服务

l 分布式协调/通知

l 集群管理

l Master 选举

l 分布式锁

l 分布式队列




#Java##笔试题目#
全部评论

相关推荐

点赞 评论 收藏
转发
2 7 评论
分享
牛客网
牛客企业服务