当前位置:首页 > > 充电吧
[导读]1.基本架构 2.ZAB协议   ZooKeeper并没有完全采用Paxos算法,而是使用了一种称为ZooKeeper Atomic Broadcast(ZAB,zookeeper原子消息广播协议)的

1.基本架构

 2.ZAB协议

   ZooKeeper并没有完全采用Paxos算法,而是使用了一种称为ZooKeeper Atomic Broadcast(ZAB,zookeeper原子消息广播协议)的协议作为其数据一致性的核心算法。

    2.1选择Leader需用半数通过才选举成成功,同时集群中已经有过半的机器与该Leader服务器完成状态同步(数据同步)才能开始服务。

    2.2所有事务请求必须由一个全局唯一的服务器来协调处理,这样的服务器称为Leader服务器,而余下的其他服务器则成为Follower服务器。Leader服务器负责将一个客户端事务请求转换成一个事务Proposal(提议),并将该Proposal分发给集群中所有的Follower服务器。之后Leader服务器需要等待所有Follower服务器的反馈,一旦超过半数的Follower服务器进行了正确反馈后,那么Leader就会再次向所有的Follower服务器分发Commit消息,要求其将前一个Proposal进行提交。

3.Leader和Follower启动过程

4.请求处理

   4.1请求处理链

      4.1.1leader请求处理链

      4.1.2follower请求处理链

    4.2处理流程

    以creater服务端为leade为例流程如下

     FollowerZooKeeperServer与LeaderZooKeeperServer处理流程的差别是FollowerRequestProcessor会将事务请求转发给leader,SendAckRequestProcessor向leader返回事务提议正确的响应,其他的处理链都是一致的。SendAckRequestProcessor和AckRequestProcessor的区别是AckRequestProcessor是leader的本地调用。FollowerRequestProcessor的事务请求的代码如下

Java代码 public void run() {         try {             while (!finished) {                 Request request = queuedRequests.take();                 if (LOG.isTraceEnabled()) {                     ZooTrace.logRequest(LOG, ZooTrace.CLIENT_REQUEST_TRACE_MASK,                             'F', request, "");                 }                 if (request == Request.requestOfDeath) {                     break;                 }                 // We want to queue the request to be processed before we submit                 // the request to the leader so that we are ready to receive                 // the response                 nextProcessor.processRequest(request);                                  // We now ship the request to the leader. As with all                 // other quorum operations, sync also follows this code                 // path, but different from others, we need to keep track                 // of the sync operations this follower has pending, so we                 // add it to pendingSyncs.                 switch (request.type) {                 case OpCode.sync:                     zks.pendingSyncs.add(request);                     zks.getFollower().request(request);                     break;                 case OpCode.create:                 case OpCode.delete:                 case OpCode.setData:                 case OpCode.setACL:                 case OpCode.createSession:                 case OpCode.closeSession:                 case OpCode.multi:                     zks.getFollower().request(request);                     break;                 }             }         } catch (Exception e) {             LOG.error("Unexpected exception causing exit", e);         }         LOG.info("FollowerRequestProcessor exited loop!");     }  

5.数据同步

    ZooKeeper集群数据同步分为4类,分别为直接差异化同步(DIFF)、先回滚再差异化同步(TRUNC+DIFF)、回滚同步(TRUNC)和全量同步(SNAP)。在同步之前,leader服务器先对peerLastZxid(该leader服务器最好处理的ZXID)、minCommittedLog(leader服务器提议缓存队列committedLog中的最小ZXID)、maxCommittedLog(leader服务器提议缓存队列committedLog中的最大ZXID)进行初始化,然后通过这3个ZXID值进行判断同步类型,并进行同步。代码见LearnerHandler的run方法:

Java代码 .....  long peerLastZxid;  StateSummary ss = null;  long zxid = qp.getZxid();  long newEpoch = leader.getEpochToPropose(this.getSid(), lastAcceptedEpoch);    if (this.getVersion() < 0x10000) {      // we are going to have to extrapolate the epoch information      long epoch = ZxidUtils.getEpochFromZxid(zxid);      ss = new StateSummary(epoch, zxid);      // fake the message      leader.waitForEpochAck(this.getSid(), ss);  } else {      byte ver[] = new byte[4];      ByteBuffer.wrap(ver).putInt(0x10000);      QuorumPacket newEpochPacket = new QuorumPacket(Leader.LEADERINFO, ZxidUtils.makeZxid(newEpoch, 0), ver, null);      oa.writeRecord(newEpochPacket, "packet");      bufferedOutput.flush();      QuorumPacket ackEpochPacket = new QuorumPacket();      ia.readRecord(ackEpochPacket, "packet");      if (ackEpochPacket.getType() != Leader.ACKEPOCH) {          LOG.error(ackEpochPacket.toString()                  + " is not ACKEPOCH");          return;        ByteBuffer bbepoch = ByteBuffer.wrap(ackEpochPacket.getData());      ss = new StateSummary(bbepoch.getInt(), ackEpochPacket.getZxid());      leader.waitForEpochAck(this.getSid(), ss);  }  peerLastZxid = ss.getLastZxid();    /* the default to send to the follower */  int packetToSend = Leader.SNAP;  long zxidToSend = 0;  long leaderLastZxid = 0;  /** the packets that the follower needs to get updates from **/  long updates = peerLastZxid;    /* we are sending the diff check if we have proposals in memory to be able to   * send a diff to the   */   ReentrantReadWriteLock lock = leader.zk.getZKDatabase().getLogLock();  ReadLock rl = lock.readLock();  try {      rl.lock();              final long maxCommittedLog = leader.zk.getZKDatabase().getmaxCommittedLog();      final long minCommittedLog = leader.zk.getZKDatabase().getminCommittedLog();      LOG.info("Synchronizing with Follower sid: " + sid              +" maxCommittedLog=0x"+Long.toHexString(maxCommittedLog)              +" minCommittedLog=0x"+Long.toHexString(minCommittedLog)              +" peerLastZxid=0x"+Long.toHexString(peerLastZxid));        LinkedList

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭