ZooKeeper简单介绍

1.概述:

  • 实现方式:Znode数据结构+watcher机制

2.Znode:

  • data:与该Znode关联的数据
  • children:该Znode下的子节点
  • stat:此为状态信息, 描述该Znode的版本, 权限等信息
  • 节点属性:
    ZooKeeper简单介绍_第1张图片

2.1 zxid

  • 致使ZooKeeper节点状态改变的每一个操作都将使节点接收到一个Zxid格式的时间戳,并且这个时间戳全局有序。也就是说,也就是说,每个对节点的改变都将产生一个唯一的Zxid。如果Zxid1的值小于Zxid2的值,那么Zxid1所对应的事件发生在Zxid2所对应的事件之前。

3.Watch触发器

  • ZooKeeper可以为所有的读操作设置watch,这些读操作包括:exists()、getChildren()及getData()。watch事件是一次性的触发器,当watch的对象状态发生改变时,将会触发此对象上watch所对应的事件。watch事件将被异步地发送给客户端,并且ZooKeeper为watch机制提供了有序的一致性保证。

4.选举机制

4.1 fast paxos(默认)

  • fast paxos流程是在选举过程中,某Server首先向所有Server提议自己要成为leader,当其它Server收到提议以后,更新epoch(选举的轮数,即逻辑时钟。随着选举的轮数++)和zxid为对方推荐的信息,并接受对方的提议,然后向对方发送接受提议完成的消息,重复这个流程,最后一定能选举出Leader。

    ZooKeeper简单介绍_第2张图片

4.2 basic paxos

  • 选举线程由当前Server发起选举的线程担任,其主要功能是对投票结果进行统计,并选出推荐的Server;

  • 选举线程首先向所有Server发起一次询问(包括自己);

  • 选举线程收到回复后,验证是否是自己发起的询问(验证zxid是否一致),然后获取对方的id(myid),并存储到当前询问对象列表中,最后获取对方提议的leader相关信息(id,zxid),并将这些信息存储到当次选举的投票记录表中;

  • 收到所有Server回复以后,就计算出zxid最大的那个Server,并将这个Server相关信息设置成下一次要投票的Server;

  • 线程将当前zxid最大的Server设置为当前Server要推荐的Leader,如果此时获胜的Server获得n/2 + 1的Server票数,设置当前推荐的leader为获胜的Server,将根据获胜的Server相关信息设置自己的状态,否则,继续这个过程,直到leader被选举出来。每个Server启动后都会重复以上流程。

    ZooKeeper简单介绍_第3张图片

你可能感兴趣的:(Spring)