📜  动物园管理员-领导人选举

📅  最后修改于: 2020-11-28 14:25:17             🧑  作者: Mango


让我们分析如何在ZooKeeper集成中选择领导节点。考虑一个集群中有N个节点。领导人选举的过程如下-

  • 所有节点都使用/ app / leader_election / guid_路径创建一个连续的临时znode

  • ZooKeeper合奏会将10位序列号附加到路径上,并且创建的znode将为/ app / leader_election / guid_0000000001,/ app / leader_election / guid_0000000002等。

  • 对于给定的实例,在znode中创建最小编号的节点将成为领导者,而其他所有节点都是跟随者。

  • 每个跟随者节点监视具有下一个最小编号的znode。例如,创建znode / app / leader_election / guid_0000000008的节点将监视znode / app / leader_election / guid_0000000007 ,而创建znode / app / leader_election / guid_0000000007的节点将监视znode / app / leader_election / guid_0000000006。

  • 如果领导者失败了,那么其对应的znode / app / leader_electionN将被删除。

  • 行中的下一个跟随者节点将通过观察者获取有关删除领导者的通知。

  • 行中的下一个跟随节点将检查是否还有其他znode的数目最小。如果没有,它将承担领导者的角色。否则,它将找到创建最小znode的节点作为leader。

  • 同样,所有其他跟随者节点都会选择创建了具有最小数量的znode的节点作为引导者。

从头开始选举领导人是一个复杂的过程。但是ZooKeeper服务使其非常简单。在下一章中,让我们继续安装ZooKeeper以进行开发。