zookeeper的数据同步机制
zookeeper 的数据同步是为了保证各节点中数据的一至性,同步时涉及两个流程,一个是正常的客户端数据提交,另一个是集群某个节点宕机在恢复后的数据同步。
客户端写入请求:
写入请求的大至流程是,收leader接收客户端写请求,并同步给各个子节点。如下图:
但实际情况要复杂的多,比如client 它并不知道哪个节点是leader 有可能写的请求会发给follower ,由follower在转发给leader进行同步处理,如下图所示
客户端写入流程说明:
-
client向zk中的server发送写请求,如果该server不是leader,则会将该写请求转发给leader server,leader将请求事务以proposal形式分发给follower;
-
当follower收到收到leader的proposal时,根据接收的先后顺序处理proposal;
-
当Leader收到follower针对某个proposal过半的ack后,则发起事务提交,重新发起一个commit的proposal