智能摘要文章源自JAVA秀-https://www.javaxiu.com/36115.html
连接到哪个Server,展示给它都是同一个视图,这是zookeeper最重要的性能。2)在任意时刻,都不会有2个Server同时有法定人数(quorum)的支持者。欢迎加入我的知识星球,一起探讨架构,交流源码。MyBatis、Redis、MongoDB、ES、分库分表、读写分离、SpringMVC、Webflux、权限、WebSocket、Dubbo、RabbitMQ、RocketMQ、Kafka、性能测试等等内容。文章源自JAVA秀-https://www.javaxiu.com/36115.html
原文约 8489 字 | 图片 9 张 | 建议阅读 17 分钟 | 评价反馈文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper 基本原理
点击关注 ? 芋道源码 文章源自JAVA秀-https://www.javaxiu.com/36115.html
收录于话题文章源自JAVA秀-https://www.javaxiu.com/36115.html
#芋道源码文章源自JAVA秀-https://www.javaxiu.com/36115.html
159个文章源自JAVA秀-https://www.javaxiu.com/36115.html
点击上方“芋道源码”,选择“设为星标”文章源自JAVA秀-https://www.javaxiu.com/36115.html
管她前浪,还是后浪?文章源自JAVA秀-https://www.javaxiu.com/36115.html
能浪的浪,才是好浪!文章源自JAVA秀-https://www.javaxiu.com/36115.html
每天 8:55 更新文章,每天掉亿点点头发...文章源自JAVA秀-https://www.javaxiu.com/36115.html
文章源自JAVA秀-https://www.javaxiu.com/36115.html 源码精品专栏文章源自JAVA秀-https://www.javaxiu.com/36115.html
原创 | Java 2020 超神之路,很肝~文章源自JAVA秀-https://www.javaxiu.com/36115.html
中文详细注释的开源项目文章源自JAVA秀-https://www.javaxiu.com/36115.html
RPC 框架 Dubbo 源码解析文章源自JAVA秀-https://www.javaxiu.com/36115.html
网络应用框架 Netty 源码解析文章源自JAVA秀-https://www.javaxiu.com/36115.html
消息中间件 RocketMQ 源码解析文章源自JAVA秀-https://www.javaxiu.com/36115.html
数据库中间件 Sharding-JDBC 和 MyCAT 源码解析文章源自JAVA秀-https://www.javaxiu.com/36115.html
作业调度中间件 Elastic-Job 源码解析文章源自JAVA秀-https://www.javaxiu.com/36115.html
分布式事务中间件 TCC-Transaction 源码解析文章源自JAVA秀-https://www.javaxiu.com/36115.html
Eureka 和 Hystrix 源码解析文章源自JAVA秀-https://www.javaxiu.com/36115.html
Java 并发源码文章源自JAVA秀-https://www.javaxiu.com/36115.html
来源:cnblogs.com/luxiaoxun/p/4887452.html文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper简介文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper设计目的文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper数据模型文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper Session文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper Watch文章源自JAVA秀-https://www.javaxiu.com/36115.html
Consistency Guarantees文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper的工作原理文章源自JAVA秀-https://www.javaxiu.com/36115.html
Leader Election文章源自JAVA秀-https://www.javaxiu.com/36115.html
Leader工作流程文章源自JAVA秀-https://www.javaxiu.com/36115.html
Leader主要有三个功能:文章源自JAVA秀-https://www.javaxiu.com/36115.html
Follower工作流程文章源自JAVA秀-https://www.javaxiu.com/36115.html
Zab: Broadcasting State Updates文章源自JAVA秀-https://www.javaxiu.com/36115.html
zookeeper集群文章源自JAVA秀-https://www.javaxiu.com/36115.html
总结
文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper简介
ZooKeeper是一个开放源码的分布式应用程序协调服务,它包含一个简单的原语集,分布式应用程序可以基于它实现同步服务,配置维护和命名服务等。文章源自JAVA秀-https://www.javaxiu.com/36115.html
文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper设计目的
1.最终一致性:client不论连接到哪个Server,展示给它都是同一个视图,这是zookeeper最重要的性能。文章源自JAVA秀-https://www.javaxiu.com/36115.html
2.可靠性:具有简单、健壮、良好的性能,如果消息m被到一台服务器接受,那么它将被所有的服务器接受。文章源自JAVA秀-https://www.javaxiu.com/36115.html
3.实时性:Zookeeper保证客户端将在一个时间间隔范围内获得服务器的更新信息,或者服务器失效的信息。但由于网络延时等原因,Zookeeper不能保证两个客户端能同时得到刚更新的数据,如果需要最新数据,应该在读数据之前调用sync()接口。文章源自JAVA秀-https://www.javaxiu.com/36115.html
4.等待无关(wait-free):慢的或者失效的client不得干预快速的client的请求,使得每个client都能有效的等待。文章源自JAVA秀-https://www.javaxiu.com/36115.html
5.原子性:更新只能成功或者失败,没有中间状态。文章源自JAVA秀-https://www.javaxiu.com/36115.html
6.顺序性:包括全局有序和偏序两种:全局有序是指如果在一台服务器上消息a在消息b前发布,则在所有Server上消息a都将在消息b前被发布;偏序是指如果一个消息b在消息a后被同一个发送者发布,a必将排在b前面。文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper数据模型
Zookeeper会维护一个具有层次关系的数据结构,它非常类似于一个标准的文件系统,如图所示:文章源自JAVA秀-https://www.javaxiu.com/36115.html
文章源自JAVA秀-https://www.javaxiu.com/36115.html
Zookeeper这种数据结构有如下这些特点:文章源自JAVA秀-https://www.javaxiu.com/36115.html
1)每个子目录项如NameService都被称作为znode,这个znode是被它所在的路径唯一标识,如Server1这个znode的标识为/NameService/Server1。文章源自JAVA秀-https://www.javaxiu.com/36115.html
2)znode可以有子节点目录,并且每个znode可以存储数据,注意EPHEMERAL(临时的)类型的目录节点不能有子节点目录。文章源自JAVA秀-https://www.javaxiu.com/36115.html
3)znode是有版本的(version),每个znode中存储的数据可以有多个版本,也就是一个访问路径中可以存储多份数据,version号自动增加。文章源自JAVA秀-https://www.javaxiu.com/36115.html
4)znode的类型:文章源自JAVA秀-https://www.javaxiu.com/36115.html
Persistent 节点,一旦被创建,便不会意外丢失,即使服务器全部重启也依然存在。每个 Persist 节点即可包含数据,也可包含子节点。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Ephemeral 节点,在创建它的客户端与服务器间的 Session 结束时自动被删除。服务器重启会导致 Session 结束,因此 Ephemeral 类型的 znode 此时也会自动删除。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Non-sequence 节点,多个客户端同时创建同一 Non-sequence 节点时,只有一个可创建成功,其它匀失败。并且创建出的节点名称与创建时指定的节点名完全一样。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Sequence 节点,创建出的节点名在指定的名称之后带有10位10进制数的序号。多个客户端创建同一名称的节点时,都能创建成功,只是序号不同。文章源自JAVA秀-https://www.javaxiu.com/36115.html
5)znode可以被监控,包括这个目录节点中存储的数据的修改,子节点目录的变化等,一旦变化可以通知设置监控的客户端,这个是Zookeeper的核心特性,Zookeeper的很多功能都是基于这个特性实现的。文章源自JAVA秀-https://www.javaxiu.com/36115.html
6)ZXID:每次对Zookeeper的状态的改变都会产生一个zxid(ZooKeeper Transaction Id),zxid是全局有序的,如果zxid1小于zxid2,则zxid1在zxid2之前发生。文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper Session
Client和Zookeeper集群建立连接,整个session状态变化如图所示:文章源自JAVA秀-https://www.javaxiu.com/36115.html
文章源自JAVA秀-https://www.javaxiu.com/36115.html
如果Client因为Timeout和Zookeeper Server失去连接,client处在CONNECTING状态,会自动尝试再去连接Server,如果在session有效期内再次成功连接到某个Server,则回到CONNECTED状态。文章源自JAVA秀-https://www.javaxiu.com/36115.html
注意:如果因为网络状态不好,client和Server失去联系,client会停留在当前状态,会尝试主动再次连接Zookeeper Server。client不能宣称自己的session expired,session expired是由Zookeeper Server来决定的,client可以选择自己主动关闭session。文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper Watch
Zookeeper watch是一种监听通知机制。Zookeeper所有的读操作getData(), getChildren()和 exists()都可以设置监视(watch),监视事件可以理解为一次性的触发器,官方定义如下:a watch event is one-time trigger, sent to the client that set the watch, whichoccurs when the data for which the watch was set changes。Watch的三个关键点:文章源自JAVA秀-https://www.javaxiu.com/36115.html
*(一次性触发)One-time trigger文章源自JAVA秀-https://www.javaxiu.com/36115.html
当设置监视的数据发生改变时,该监视事件会被发送到客户端,例如,如果客户端调用了getData("/znode1", true) 并且稍后 /znode1 节点上的数据发生了改变或者被删除了,客户端将会获取到 /znode1 发生变化的监视事件,而如果 /znode1 再一次发生了变化,除非客户端再次对/znode1 设置监视,否则客户端不会收到事件通知。文章源自JAVA秀-https://www.javaxiu.com/36115.html
*(发送至客户端)Sent to the client文章源自JAVA秀-https://www.javaxiu.com/36115.html
Zookeeper客户端和服务端是通过 socket 进行通信的,由于网络存在故障,所以监视事件很有可能不会成功地到达客户端,监视事件是异步发送至监视者的,Zookeeper 本身提供了顺序保证(ordering guarantee):即客户端只有首先看到了监视事件后,才会感知到它所设置监视的znode发生了变化(a client will never see a change for which it has set a watch until it first sees the watch event)。网络延迟或者其他因素可能导致不同的客户端在不同的时刻感知某一监视事件,但是不同的客户端所看到的一切具有一致的顺序。文章源自JAVA秀-https://www.javaxiu.com/36115.html
*(被设置 watch 的数据)The data for which the watch was set文章源自JAVA秀-https://www.javaxiu.com/36115.html
这意味着znode节点本身具有不同的改变方式。你也可以想象 Zookeeper 维护了两条监视链表:数据监视和子节点监视(data watches and child watches) getData() 和exists()设置数据监视,getChildren()设置子节点监视。或者你也可以想象 Zookeeper 设置的不同监视返回不同的数据,getData() 和 exists() 返回znode节点的相关信息,而getChildren() 返回子节点列表。因此,setData() 会触发设置在某一节点上所设置的数据监视(假定数据设置成功),而一次成功的create() 操作则会出发当前节点上所设置的数据监视以及父节点的子节点监视。一次成功的 delete操作将会触发当前节点的数据监视和子节点监视事件,同时也会触发该节点父节点的child watch。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Zookeeper 中的监视是轻量级的,因此容易设置、维护和分发。当客户端与 Zookeeper 服务器失去联系时,客户端并不会收到监视事件的通知,只有当客户端重新连接后,若在必要的情况下,以前注册的监视会重新被注册并触发,对于开发人员来说这通常是透明的。只有一种情况会导致监视事件的丢失,即:通过exists()设置了某个znode节点的监视,但是如果某个客户端在此znode节点被创建和删除的时间间隔内与zookeeper服务器失去了联系,该客户端即使稍后重新连接 zookeeper服务器后也得不到事件通知。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Consistency Guarantees
Zookeeper是一个高效的、可扩展的服务,read和write操作都被设计为快速的,read比write操作更快。文章源自JAVA秀-https://www.javaxiu.com/36115.html
顺序一致性(Sequential Consistency):从一个客户端来的更新请求会被顺序执行。文章源自JAVA秀-https://www.javaxiu.com/36115.html
原子性(Atomicity):更新要么成功要么失败,没有部分成功的情况。文章源自JAVA秀-https://www.javaxiu.com/36115.html
唯一的系统镜像(Single System Image):无论客户端连接到哪个Server,看到系统镜像是一致的。文章源自JAVA秀-https://www.javaxiu.com/36115.html
可靠性(Reliability):更新一旦有效,持续有效,直到被覆盖。文章源自JAVA秀-https://www.javaxiu.com/36115.html
时间线(Timeliness):保证在一定的时间内各个客户端看到的系统信息是一致的。文章源自JAVA秀-https://www.javaxiu.com/36115.html
ZooKeeper的工作原理
在zookeeper的集群中,各个节点共有下面3种角色和4种状态:文章源自JAVA秀-https://www.javaxiu.com/36115.html
角色:leader,follower,observer文章源自JAVA秀-https://www.javaxiu.com/36115.html
状态:leading,following,observing,looking文章源自JAVA秀-https://www.javaxiu.com/36115.html
Zookeeper的核心是原子广播,这个机制保证了各个Server之间的同步。实现这个机制的协议叫做Zab协议(ZooKeeper Atomic Broadcast protocol)。Zab协议有两种模式,它们分别是恢复模式(Recovery选主)和广播模式(Broadcast同步)。当服务启动或者在领导者崩溃后,Zab就进入了恢复模式,当领导者被选举出来,且大多数Server完成了和leader的状态同步以后,恢复模式就结束了。状态同步保证了leader和Server具有相同的系统状态。文章源自JAVA秀-https://www.javaxiu.com/36115.html
为了保证事务的顺序一致性,zookeeper采用了递增的事务id号(zxid)来标识事务。所有的提议(proposal)都在被提出的时候加上了zxid。实现中zxid是一个64位的数字,它高32位是epoch用来标识leader关系是否改变,每次一个leader被选出来,它都会有一个新的epoch,标识当前属于那个leader的统治时期。低32位用于递增计数。文章源自JAVA秀-https://www.javaxiu.com/36115.html
每个Server在工作过程中有4种状态:文章源自JAVA秀-https://www.javaxiu.com/36115.html
LOOKING:当前Server不知道leader是谁,正在搜寻。文章源自JAVA秀-https://www.javaxiu.com/36115.html
LEADING:当前Server即为选举出来的leader。文章源自JAVA秀-https://www.javaxiu.com/36115.html
FOLLOWING:leader已经选举出来,当前Server与之同步。文章源自JAVA秀-https://www.javaxiu.com/36115.html
OBSERVING:observer的行为在大多数情况下与follower完全一致,但是他们不参加选举和投票,而仅仅接受(observing)选举和投票的结果。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Leader Election
当leader崩溃或者leader失去大多数的follower,这时候zk进入恢复模式,恢复模式需要重新选举出一个新的leader,让所有的Server都恢复到一个正确的状态。Zk的选举算法有两种:一种是基于basic paxos实现的,另外一种是基于fast paxos算法实现的。系统默认的选举算法为fast paxos。先介绍basic paxos流程:文章源自JAVA秀-https://www.javaxiu.com/36115.html
1.选举线程由当前Server发起选举的线程担任,其主要功能是对投票结果进行统计,并选出推荐的Server;文章源自JAVA秀-https://www.javaxiu.com/36115.html
2.选举线程首先向所有Server发起一次询问(包括自己);文章源自JAVA秀-https://www.javaxiu.com/36115.html
3.选举线程收到回复后,验证是否是自己发起的询问(验证zxid是否一致),然后获取对方的id(myid),并存储到当前询问对象列表中,最后获取对方提议的leader相关信息(id,zxid),并将这些信息存储到当次选举的投票记录表中;文章源自JAVA秀-https://www.javaxiu.com/36115.html
4.收到所有Server回复以后,就计算出zxid最大的那个Server,并将这个Server相关信息设置成下一次要投票的Server;文章源自JAVA秀-https://www.javaxiu.com/36115.html
5.线程将当前zxid最大的Server设置为当前Server要推荐的Leader,如果此时获胜的Server获得n/2 + 1的Server票数,设置当前推荐的leader为获胜的Server,将根据获胜的Server相关信息设置自己的状态,否则,继续这个过程,直到leader被选举出来。文章源自JAVA秀-https://www.javaxiu.com/36115.html
通过流程分析我们可以得出:要使Leader获得多数Server的支持,则Server总数必须是奇数2n+1,且存活的Server的数目不得少于n+1.文章源自JAVA秀-https://www.javaxiu.com/36115.html
每个Server启动后都会重复以上流程。在恢复模式下,如果是刚从崩溃状态恢复的或者刚启动的server还会从磁盘快照中恢复数据和会话信息,zk会记录事务日志并定期进行快照,方便在恢复时进行状态恢复。文章源自JAVA秀-https://www.javaxiu.com/36115.html
fast paxos流程是在选举过程中,某Server首先向所有Server提议自己要成为leader,当其它Server收到提议以后,解决epoch和zxid的冲突,并接受对方的提议,然后向对方发送接受提议完成的消息,重复这个流程,最后一定能选举出Leader。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Leader工作流程
Leader主要有三个功能:
1.恢复数据;文章源自JAVA秀-https://www.javaxiu.com/36115.html
2.维持与follower的心跳,接收follower请求并判断follower的请求消息类型;文章源自JAVA秀-https://www.javaxiu.com/36115.html
3.follower的消息类型主要有PING消息、REQUEST消息、ACK消息、REVALIDATE消息,根据不同的消息类型,进行不同的处理。文章源自JAVA秀-https://www.javaxiu.com/36115.html
PING消息是指follower的心跳信息;REQUEST消息是follower发送的提议信息,包括写请求及同步请求;文章源自JAVA秀-https://www.javaxiu.com/36115.html
ACK消息是follower的对提议的回复,超过半数的follower通过,则commit该提议;文章源自JAVA秀-https://www.javaxiu.com/36115.html
REVALIDATE消息是用来延长SESSION有效时间。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Follower工作流程
Follower主要有四个功能:文章源自JAVA秀-https://www.javaxiu.com/36115.html
1.向Leader发送请求(PING消息、REQUEST消息、ACK消息、REVALIDATE消息);文章源自JAVA秀-https://www.javaxiu.com/36115.html
2.接收Leader消息并进行处理;文章源自JAVA秀-https://www.javaxiu.com/36115.html
3.接收Client的请求,如果为写请求,发送给Leader进行投票;文章源自JAVA秀-https://www.javaxiu.com/36115.html
4.返回Client结果。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Follower的消息循环处理如下几种来自Leader的消息:文章源自JAVA秀-https://www.javaxiu.com/36115.html
1.PING消息:心跳消息文章源自JAVA秀-https://www.javaxiu.com/36115.html
2.PROPOSAL消息:Leader发起的提案,要求Follower投票文章源自JAVA秀-https://www.javaxiu.com/36115.html
3.COMMIT消息:服务器端最新一次提案的信息文章源自JAVA秀-https://www.javaxiu.com/36115.html
4.UPTODATE消息:表明同步完成文章源自JAVA秀-https://www.javaxiu.com/36115.html
5.REVALIDATE消息:根据Leader的REVALIDATE结果,关闭待revalidate的session还是允许其接受消息文章源自JAVA秀-https://www.javaxiu.com/36115.html
6.SYNC消息:返回SYNC结果到客户端,这个消息最初由客户端发起,用来强制得到最新的更新。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Zab: Broadcasting State Updates
Zookeeper Server接收到一次request,如果是follower,会转发给leader,Leader执行请求并通过Transaction的形式广播这次执行。Zookeeper集群如何决定一个Transaction是否被commit执行?通过“两段提交协议”(a two-phase commit):文章源自JAVA秀-https://www.javaxiu.com/36115.html
Leader给所有的follower发送一个PROPOSAL消息。文章源自JAVA秀-https://www.javaxiu.com/36115.html
一个follower接收到这次PROPOSAL消息,写到磁盘,发送给leader一个ACK消息,告知已经收到。文章源自JAVA秀-https://www.javaxiu.com/36115.html
当Leader收到法定人数(quorum)的follower的ACK时候,发送commit消息执行。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Zab协议保证:文章源自JAVA秀-https://www.javaxiu.com/36115.html
1) 如果leader以T1和T2的顺序广播,那么所有的Server必须先执行T1,再执行T2。文章源自JAVA秀-https://www.javaxiu.com/36115.html
2) 如果任意一个Server以T1、T2的顺序commit执行,其他所有的Server也必须以T1、T2的顺序执行。文章源自JAVA秀-https://www.javaxiu.com/36115.html
“两段提交协议”最大的问题是如果Leader发送了PROPOSAL消息后crash或暂时失去连接,会导致整个集群处在一种不确定的状态(follower不知道该放弃这次提交还是执行提交)。Zookeeper这时会选出新的leader,请求处理也会移到新的leader上,不同的leader由不同的epoch标识。切换Leader时,需要解决下面两个问题:文章源自JAVA秀-https://www.javaxiu.com/36115.html
Never forget delivered messages文章源自JAVA秀-https://www.javaxiu.com/36115.html
Leader在COMMIT投递到任何一台follower之前crash,只有它自己commit了。新Leader必须保证这个事务也必须commit。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Let go of messages that are skipped文章源自JAVA秀-https://www.javaxiu.com/36115.html
Leader产生某个proposal,但是在crash之前,没有follower看到这个proposal。该server恢复时,必须丢弃这个proposal。文章源自JAVA秀-https://www.javaxiu.com/36115.html
Zookeeper会尽量保证不会同时有2个活动的Leader,因为2个不同的Leader会导致集群处在一种不一致的状态,所以Zab协议同时保证:文章源自JAVA秀-https://www.javaxiu.com/36115.html
1) 在新的leader广播Transaction之前,先前Leader commit的Transaction都会先执行。文章源自JAVA秀-https://www.javaxiu.com/36115.html
2) 在任意时刻,都不会有2个Server同时有法定人数(quorum)的支持者。文章源自JAVA秀-https://www.javaxiu.com/36115.html
这里的quorum是一半以上的Server数目,确切的说是有投票权力的Server(不包括Observer)。文章源自JAVA秀-https://www.javaxiu.com/36115.html
zookeeper集群
zookeeper集群配置:文章源自JAVA秀-https://www.javaxiu.com/36115.html
tickTime=2000initLimit=10syncLimit=5dataDir=/home/zookeeper-3.4.14/dataclientPort=2181autopurge.snapRetainCount=5autopurge.purgeInterval=2server.1= 10.217.59.111:2888:3888server.2= 10.217.59.112:2888:3888server.3= 10.217.59.113:2888:3888
分别在每个服务器/home/zookeeper-3.4.14下创建myid文件,内容如下:文章源自JAVA秀-https://www.javaxiu.com/36115.html
1(该数字对应zoo.cfg中的server.x中的x)
日志配置:文章源自JAVA秀-https://www.javaxiu.com/36115.html
log4j.properties修改:zookeeper.root.logger=INFO, ROLLINGFILEzkEnv.sh修改:if [ "x${ZOO_LOG_DIR}" = "x" ]then ZOO_LOG_DIR="/home/zookeeper-3.4.14/log"fiif [ "x${ZOO_LOG4J_PROP}" = "x" ]then ZOO_LOG4J_PROP="INFO,ROLLINGFILE"fi
启停:bin/zkServer.sh start/stop/status文章源自JAVA秀-https://www.javaxiu.com/36115.html
zk命令:bin/zkCli.sh -server localhost:2181文章源自JAVA秀-https://www.javaxiu.com/36115.html
总结
简单介绍了Zookeeper的基本原理,数据模型,Session,Watch机制,一致性保证,Leader Election,Leader和Follower的工作流程和Zab协议。文章源自JAVA秀-https://www.javaxiu.com/36115.html
- END -文章源自JAVA秀-https://www.javaxiu.com/36115.html
欢迎加入我的知识星球,一起探讨架构,交流源码。加入方式,长按下方二维码噢:文章源自JAVA秀-https://www.javaxiu.com/36115.html
文章源自JAVA秀-https://www.javaxiu.com/36115.html
已在知识星球更新源码解析如下:文章源自JAVA秀-https://www.javaxiu.com/36115.html
文章源自JAVA秀-https://www.javaxiu.com/36115.html
文章源自JAVA秀-https://www.javaxiu.com/36115.html
文章源自JAVA秀-https://www.javaxiu.com/36115.html
文章源自JAVA秀-https://www.javaxiu.com/36115.html
最近更新《芋道 SpringBoot 2.X 入门》系列,已经 20 余篇,覆盖了 MyBatis、Redis、MongoDB、ES、分库分表、读写分离、SpringMVC、Webflux、权限、WebSocket、Dubbo、RabbitMQ、RocketMQ、Kafka、性能测试等等内容。文章源自JAVA秀-https://www.javaxiu.com/36115.html
提供近 3W 行代码的 SpringBoot 示例,以及超 4W 行代码的电商微服务项目。文章源自JAVA秀-https://www.javaxiu.com/36115.html
获取方式:点“在看”,关注公众号并回复 666 领取,更多内容陆续奉上。文章源自JAVA秀-https://www.javaxiu.com/36115.html
文章源自JAVA秀-https://www.javaxiu.com/36115.html
文章有帮助的话,在看,转发吧。谢谢支持哟 (*^__^*)文章源自JAVA秀-https://www.javaxiu.com/36115.html
阅读原文文章源自JAVA秀-https://www.javaxiu.com/36115.html

评论