ZAB协议并不是Paxos算法的一个典型实现,在讲解ZAB和Paxos之间的区别之前,我们首先来看下两者的联系。

  • 两者都存在一个类似于Leader进程的角色,由其负责协调多个Follow进程的运行。
  • Leader进程都会等待超过半数的Follower做出正确的反馈后,才会将一个提案进行提交。
  • 在ZAB协议中,每个Proposal中都包含了一个epoch值,用来代表当前Leader周期,在Paxos算法中,同样存在这样一个标识,只是名字变成了Ballot。

在Paxos算法中,一个新选举产生的主进程会进行两个阶段的工作。第一阶段被称为读阶段,在这个阶段中,这个新的主进程会通过和所有其他进程进行通信的方式来收集上一个主进程的提案,并将他们提交。第二阶段被称为写阶段,在这个阶段,当前主进程开始提出他自己的提案。在Paxos算法设计的基础上,ZAB协议额外添加了一个同步阶段。在同步阶段之前,ZAB协议也存在一个和Paxos算法中的读阶段非常类似的过程,称为发现(Discovery)阶段。在同步阶段中,新的Leader会确保存在过半的Follower已经提交了之前Leader周期中的所有事务Proposal。这一同步阶段的引入,能够有效地保证Leader在新的周期中提出事务Proposal之前,所有的进程都已经完成了对之前所有事务Proposal的提交。一旦完成同步阶段后,那么ZAB就会执行和Paxos算法类似的写阶段。

总的来讲,ZAB协议和Paxos算法的本质区别在于,两者的设计目标不太一样。ZAB协议主要用于构建一个高可用的分布式数据主备系统,例如ZooKeeper,而Paxos算法则是用于构建一个分布式的一致性状态机系统。

最新文章

  1. python发送邮件及附件
  2. wamp apache 的虚拟机配置 多域名访问 的 三部曲
  3. 谈谈Java面向对象的三大特性
  4. static_cast .xml
  5. LeetCode24 Swap Nodes in Pairs
  6. python pro practice
  7. IOS性能调优系列:Analyze静态分析
  8. [AngularJS] Using $parse Service
  9. OpenStack搭建遇到的问题
  10. Web API的CORS
  11. 批量下载google 字体小工具
  12. NFS 安装与配置
  13. Hello The Merciless World!
  14. Hadoop HDFS 设计随想
  15. tensorflow入门(1):构造线性回归模型
  16. android学习:apiDemos导入时R.java无法生成的问题
  17. ElasticSearch的matchQuery与termQuery区别
  18. Oracle中对number类型数据to_char()出现各位少0,或者值为###的处理
  19. Using a Microsoft Account to Logon and Resulting Internet Communication in Windows 8
  20. HTML切换页面IE版本

热门文章

  1. zabbix server 端安装
  2. Redis 配置和使用
  3. Linux使用yum安装rpm包
  4. 17.Django表单验证
  5. bug_1——oracle listagg():列转行
  6. Xen虚拟化基础篇
  7. uCGUI 按键窗口切换机制(更新篇)
  8. P3768 【简单的数学题】
  9. python作用域和js作用域的比较
  10. MySQL存储过程入门教程