Java面试题之:Zookeeper

Java面试题之:Zookeeper

  • 一、Zookeeper概念
  • 二、Zookeeper 角色
      • ①Leader
      • ②Follower
      • ③Observer

一、Zookeeper概念

  Zookeeper 是一个分布式协调服务,可用于服务发现,分布式锁,分布式领导选举,配置管理等。Zookeeper 提供了一个类似于 Linux 文件系统的树形结构(可认为是轻量级的内存文件系统,但只适合存少量信息,完全不适合存储大量文件或者大文件),同时提供了对于每个节点的监控与通知机制。

二、Zookeeper 角色

  Zookeeper 集群是一个基于主从复制的高可用集群,每个服务器承担如下三种角色中的一种。

①Leader

  1. 一个 Zookeeper 集群同一时间只会有一个实际工作的 Leader,它会发起并维护与各 Follwer及 Observer 间的心跳。
  2. 所有的写操作必须要通过 Leader 完成再由 Leader 将写操作广播给其它服务器。只要有超过半数节点(不包括 observeer 节点)写入成功,该写请求就会被提交(类 2PC 协议)

②Follower

  1. 一个 Zookeeper 集群可能同时存在多个 Follower,它会响应 Leader 的心跳,
  2. Follower 可直接处理并返回客户端的读请求,同时会将写请求转发给 Leader 处理
  3. 并且负责在 Leader 处理写请求时对请求进行投票

③Observer

  角色与 Follower 类似,但是无投票权。Zookeeper 需保证高可用和强一致性,为了支持更多的客户端,需要增加更多 Server;Server 增多,投票阶段延迟增大,影响性能;引入 Observer,Observer 不参与投票; Observers 接受客户端的连接,并将写请求转发给 leader 节点; 加入更多 Observer 节点,提高伸缩性,同时不影响吞吐率。
Java面试题之:Zookeeper_第1张图片

你可能感兴趣的:(The,interview,questions,java,zookeeper,分布式,面试题)