ZooKeeper 中的服务器角色分为以下几种:
1. Leader(领导者):一个 ZooKeeper 集群中只有一个 Leader 角色的服务器。Leader 负责协调集群中所有的读写操作,并维护数据的一致性。它负责处理客户端的所有写请求,并将这些变更复制到其他服务器(即 Follower 和 Observer)。
2. Follower(跟随者):除了 Leader 之外的服务器都是 Follower 角色。Follower 从 Leader 处复制和同步数据变更,参与选举 Leader 的过程,并处理客户端的读请求。Follower 没有对数据进行修改的权限,在集群中充当备份节点。
3. Observer(观察者):Observer 与 Follower 类似,但不参与 Leader 选举和写操作的复制。Observer 主要负责处理客户端的读请求,并从 Leader 或 Follower 处获取最新的数据副本,从而降低 Leader 的负载。
4. Standalone(独立模式):在独立模式下,ZooKeeper 仅由单个服务器组成,既不选举 Leader,也没有 Follower 或 Observer 的概念。这种模式适用于开发和测试环境,以及小规模的部署。
Leader 负责管理集群的写操作,并通过复制和投票机制保持数据的一致性。Follower 和 Observer 则主要负责处理读操作,提供数据的可用性和容错能力。在正常运行时,Leader 和 Follower/Observer 之间保持心跳通信,以确保集群的高可用性。
每个服务器角色都有其特定的职责,通过协同工作,它们构成了一个分布式的 ZooKeeper 集群,提供高性能、高可用性和一致性的数据服务。