一.ZAB协议三阶段

– 发现(Discovery),即选举Leader过程
– 同步(Synchronization),选举出新的Leader后,Follwer或者Observer从Leader同步最新的数据

– 广播,同步完成后,就可以接收客户端新的事务请求,并进行消息广播,实现数据在集群节点的副本存储

二.服务器状态

1.LOOKING
寻找Leader状态,当服务器处于此状态时,表示当前没有Leader,需要进入选举流程
2.FOLLOWING
跟随者状态,表明当前服务器角色是Follower
3.OBSERVING
观察者状态,表明当前服务器角色是Observer
4.LEADING
领导者状态,表明当前服务器角色是Leader

三.集群链接建立过程

基于TCP协议,为了避免重复创建两个节点之间的tcp连接,zk按照myid数值方向来建立连接,即小数的节点发起大的
节点连接

例如,3台机器id分别为1/2/3,则发起链接的过程为:1发起对2的链接,1发起对3的链接,2发起对3的链接

四.leader选举的触发时机

五.影响成为leader的因素

优先用数据的新旧,其次用myid的大小

ps:zxid的构成

六.leader选举的过程

初次选举过程

宕机选举

宕机选举完毕后,现leader和follower有可能会有一定的差异,需要进行同步

七.广播

最新文章

  1. Arcmap中加载互联网地图资源
  2. poj2406 周期
  3. Python队列服务 Python RQ Functions from the __main__ module cannot be processed by workers.
  4. css3学习--css3动画详解二(3d效果)
  5. 自定义函数中的参数返回值 “-> (Int -> Int)”的问题
  6. docker 服务注册
  7. tomcat主目录
  8. C语言初学 简单定义圆的面积计算问题
  9. HDU Today
  10. 8. 理解ZooKeeper的内部工作原理
  11. [java]负数的二进制编码——越是基础的越是要掌握
  12. LVM备份(2)-创建LVM逻辑卷
  13. Web前端学习第三天(cookie 二)
  14. Jmeter接口测试问题及解决方法积累
  15. jQuery 事件 - triggerHandler() 方法
  16. 【转】前端框架天下三分:Angular React 和 Vue的比较
  17. 20175234 2018-2019-2 《Java程序设计》第四周学习总结
  18. FullWebBrowserCookie 取得WebBrowser的完整Cookie
  19. git客户端msysGit和TortoiseGit使用
  20. linux下tomcat、jenkins环境搭建

热门文章

  1. Python函数独立星号(*)分隔的命名关键字参数
  2. PyQt(Python+Qt)学习随笔:QListView的movement属性
  3. 测试与发布( Alpha版本 )
  4. Apriori 算法-如何进行关联规则挖掘
  5. Codeforces Edu Round 66 A-E
  6. 题解-洛谷P4724 【模板】三维凸包
  7. Python 中的哈希表
  8. html标签学习1
  9. Day10 python高级特性-- 生成器 Generator
  10. ubuntu 16.04安装adobe reader