网易首页 > 网易号 > 正文 申请入驻

ZooKeeper 基本原理

0
分享至

推荐大家关注一个公众号

后台回复“大礼包”有惊喜礼包!

日英文

Alter what is changeable, and accept what is mutable, don't let yourself become unacceptable.

改变能改变的,接受不能改变的,别让自己成为不可接受的。

每日掏心话

岁月缠绕在指缝里,温和的流走,一季的悲伤,徜徉在心湖,如若,仰望,便如七月明媚忧伤。

责编:乐乐 | 来自:阿凡卢 链接:cnblogs.com/luxiaoxun/p/4887452.html

往日回顾:

正文

ZooKeeper简介

ZooKeeper是一个开放源码的分布式应用程序协调服务,它包含一个简单的原语集,分布式应用程序可以基于它实现同步服务,配置维护和命名服务等。

ZooKeeper设计目的

  1. 最终一致性:client不论连接到哪个Server,展示给它都是同一个视图,这是zookeeper最重要的性能。

  2. 可靠性:具有简单、健壮、良好的性能,如果消息m被到一台服务器接受,那么它将被所有的服务器接受。

  3. 实时性:Zookeeper保证客户端将在一个时间间隔范围内获得服务器的更新信息,或者服务器失效的信息。但由于网络延时等原因,Zookeeper不能保证两个客户端能同时得到刚更新的数据,如果需要最新数据,应该在读数据之前调用sync()接口。

  4. 等待无关(wait-free):慢的或者失效的client不得干预快速的client的请求,使得每个client都能有效的等待。

  5. 原子性:更新只能成功或者失败,没有中间状态。

  6. 顺序性:包括全局有序和偏序两种:全局有序是指如果在一台服务器上消息a在消息b前发布,则在所有Server上消息a都将在消息b前被发布;偏序是指如果一个消息b在消息a后被同一个发送者发布,a必将排在b前面。

ZooKeeper数据模型

Zookeeper会维护一个具有层次关系的数据结构,它非常类似于一个标准的文件系统,如图所示:

Zookeeper这种数据结构有如下这些特点:

1)每个子目录项如NameService都被称作为znode,这个znode是被它所在的路径唯一标识,如Server1这个znode的标识为/NameService/Server1。

2)znode可以有子节点目录,并且每个znode可以存储数据,注意EPHEMERAL(临时的)类型的目录节点不能有子节点目录。

3)znode是有版本的(version),每个znode中存储的数据可以有多个版本,也就是一个访问路径中可以存储多份数据,version号自动增加。

4)znode的类型:

  • Persistent 节点,一旦被创建,便不会意外丢失,即使服务器全部重启也依然存在。每个 Persist 节点即可包含数据,也可包含子节点。

  • Ephemeral 节点,在创建它的客户端与服务器间的 Session 结束时自动被删除。服务器重启会导致 Session 结束,因此 Ephemeral 类型的 znode 此时也会自动删除。

  • Non-sequence 节点,多个客户端同时创建同一 Non-sequence 节点时,只有一个可创建成功,其它匀失败。并且创建出的节点名称与创建时指定的节点名完全一样。

  • Sequence 节点,创建出的节点名在指定的名称之后带有10位10进制数的序号。多个客户端创建同一名称的节点时,都能创建成功,只是序号不同。

5)znode可以被监控,包括这个目录节点中存储的数据的修改,子节点目录的变化等,一旦变化可以通知设置监控的客户端,这个是Zookeeper的核心特性,Zookeeper的很多功能都是基于这个特性实现的。

6)ZXID:每次对Zookeeper的状态的改变都会产生一个zxid(ZooKeeper Transaction Id),zxid是全局有序的,如果zxid1小于zxid2,则zxid1在zxid2之前发生。

ZooKeeper Session

Client和Zookeeper集群建立连接,整个session状态变化如图所示:

如果Client因为Timeout和Zookeeper Server失去连接,client处在CONNECTING状态,会自动尝试再去连接Server,如果在session有效期内再次成功连接到某个Server,则回到CONNECTED状态。

注意:如果因为网络状态不好,client和Server失去联系,client会停留在当前状态,会尝试主动再次连接Zookeeper Server。client不能宣称自己的session expired,session expired是由Zookeeper Server来决定的,client可以选择自己主动关闭session。
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的三个关键点:

(一次性触发)One-time trigger

当设置监视的数据发生改变时,该监视事件会被发送到客户端,例如,如果客户端调用了getData("/znode1", true) 并且稍后 /znode1 节点上的数据发生了改变或者被删除了,客户端将会获取到 /znode1 发生变化的监视事件,而如果 /znode1 再一次发生了变化,除非客户端再次对/znode1 设置监视,否则客户端不会收到事件通知。

(发送至客户端)Sent to the client

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)。

网络延迟或者其他因素可能导致不同的客户端在不同的时刻感知某一监视事件,但是不同的客户端所看到的一切具有一致的顺序。

(被设置 watch 的数据)The data for which the watch was set

这意味着znode节点本身具有不同的改变方式。你也可以想象 Zookeeper 维护了两条监视链表:数据监视和子节点监视(data watches and child watches) getData() 和exists()设置数据监视,getChildren()设置子节点监视。或者你也可以想象 Zookeeper 设置的不同监视返回不同的数据,getData() 和 exists() 返回znode节点的相关信息,而getChildren() 返回子节点列表。

因此,setData() 会触发设置在某一节点上所设置的数据监视(假定数据设置成功),而一次成功的create() 操作则会出发当前节点上所设置的数据监视以及父节点的子节点监视。一次成功的 delete操作将会触发当前节点的数据监视和子节点监视事件,同时也会触发该节点父节点的child watch。

Zookeeper 中的监视是轻量级的,因此容易设置、维护和分发。当客户端与 Zookeeper 服务器失去联系时,客户端并不会收到监视事件的通知,只有当客户端重新连接后,若在必要的情况下,以前注册的监视会重新被注册并触发,对于开发人员来说这通常是透明的。

只有一种情况会导致监视事件的丢失,即:通过exists()设置了某个znode节点的监视,但是如果某个客户端在此znode节点被创建和删除的时间间隔内与zookeeper服务器失去了联系,该客户端即使稍后重新连接 zookeeper服务器后也得不到事件通知。

Consistency Guarantees

Zookeeper是一个高效的、可扩展的服务,read和write操作都被设计为快速的,read比write操作更快。

  • 顺序一致性(Sequential Consistency):从一个客户端来的更新请求会被顺序执行。

  • 原子性(Atomicity):更新要么成功要么失败,没有部分成功的情况。

  • 唯一的系统镜像(Single System Image):无论客户端连接到哪个Server,看到系统镜像是一致的。

  • 可靠性(Reliability):更新一旦有效,持续有效,直到被覆盖。

  • 时间线(Timeliness):保证在一定的时间内各个客户端看到的系统信息是一致的。

ZooKeeper的工作原理

在zookeeper的集群中,各个节点共有下面3种角色和4种状态:

  • 角色:leader,follower,observer

  • 状态:leading,following,observing,looking

Zookeeper的核心是原子广播,这个机制保证了各个Server之间的同步。实现这个机制的协议叫做Zab协议(ZooKeeper Atomic Broadcast protocol)。Zab协议有两种模式,它们分别是恢复模式(Recovery选主)和广播模式(Broadcast同步)。

当服务启动或者在领导者崩溃后,Zab就进入了恢复模式,当领导者被选举出来,且大多数Server完成了和leader的状态同步以后,恢复模式就结束了。状态同步保证了leader和Server具有相同的系统状态。

为了保证事务的顺序一致性,zookeeper采用了递增的事务id号(zxid)来标识事务。所有的提议(proposal)都在被提出的时候加上了zxid。

实现中zxid是一个64位的数字,它高32位是epoch用来标识leader关系是否改变,每次一个leader被选出来,它都会有一个新的epoch,标识当前属于那个leader的统治时期。低32位用于递增计数。

每个Server在工作过程中有4种状态:

  • LOOKING:当前Server不知道leader是谁,正在搜寻。

  • LEADING:当前Server即为选举出来的leader。

  • FOLLOWING:leader已经选举出来,当前Server与之同步。

  • OBSERVING:observer的行为在大多数情况下与follower完全一致,但是他们不参加选举和投票,而仅仅接受(observing)选举和投票的结果。

Leader Election

当leader崩溃或者leader失去大多数的follower,这时候zk进入恢复模式,恢复模式需要重新选举出一个新的leader,让所有的Server都恢复到一个正确的状态。Zk的选举算法有两种:一种是基于basic paxos实现的,另外一种是基于fast paxos算法实现的。系统默认的选举算法为fast paxos。先介绍basic paxos流程:

  1. 选举线程由当前Server发起选举的线程担任,其主要功能是对投票结果进行统计,并选出推荐的Server;

  2. 选举线程首先向所有Server发起一次询问(包括自己);

  3. 收到所有Server回复以后,就计算出zxid最大的那个Server,并将这个Server相关信息设置成下一次要投票的Server;

  4. 线程将当前zxid最大的Server设置为当前Server要推荐的Leader,如果此时获胜的Server获得n/2 + 1的Server票数,设置当前推荐的leader为获胜的Server,将根据获胜的Server相关信息设置自己的状态,否则,继续这个过程,直到leader被选举出来。

通过流程分析我们可以得出:要使Leader获得多数Server的支持,则Server总数必须是奇数2n+1,且存活的Server的数目不得少于n+1.

每个Server启动后都会重复以上流程。在恢复模式下,如果是刚从崩溃状态恢复的或者刚启动的server还会从磁盘快照中恢复数据和会话信息,zk会记录事务日志并定期进行快照,方便在恢复时进行状态恢复。

fast paxos流程是在选举过程中,某Server首先向所有Server提议自己要成为leader,当其它Server收到提议以后,解决epoch和zxid的冲突,并接受对方的提议,然后向对方发送接受提议完成的消息,重复这个流程,最后一定能选举出Leader。

Leader工作流程

Leader主要有三个功能:

  1. 恢复数据;

  2. 维持与follower的心跳,接收follower请求并判断follower的请求消息类型;

  3. follower的消息类型主要有PING消息、REQUEST消息、ACK消息、REVALIDATE消息,根据不同的消息类型,进行不同的处理。

说明:

PING消息是指follower的心跳信息;REQUEST消息是follower发送的提议信息,包括写请求及同步请求; ACK消息是follower的对提议的回复,超过半数的follower通过,则commit该提议; REVALIDATE消息是用来延长SESSION有效时间。
Follower工作流程

Follower主要有四个功能:

  1. 向Leader发送请求(PING消息、REQUEST消息、ACK消息、REVALIDATE消息);

  2. 接收Leader消息并进行处理;

  3. 接收Client的请求,如果为写请求,发送给Leader进行投票;

  4. 返回Client结果。

Follower的消息循环处理如下几种来自Leader的消息:

  1. PING消息:心跳消息

  2. PROPOSAL消息:Leader发起的提案,要求Follower投票

  3. COMMIT消息:服务器端最新一次提案的信息

  4. UPTODATE消息:表明同步完成

  5. REVALIDATE消息:根据Leader的REVALIDATE结果,关闭待revalidate的session还是允许其接受消息

  6. SYNC消息:返回SYNC结果到客户端,这个消息最初由客户端发起,用来强制得到最新的更新。

Zab: Broadcasting State Updates

Zookeeper Server接收到一次request,如果是follower,会转发给leader,Leader执行请求并通过Transaction的形式广播这次执行。Zookeeper集群如何决定一个Transaction是否被commit执行?通过“两段提交协议”(a two-phase commit):

  • Leader给所有的follower发送一个PROPOSAL消息。

  • 一个follower接收到这次PROPOSAL消息,写到磁盘,发送给leader一个ACK消息,告知已经收到。

  • 当Leader收到法定人数(quorum)的follower的ACK时候,发送commit消息执行。

Zab协议保证:

  • 如果leader以T1和T2的顺序广播,那么所有的Server必须先执行T1,再执行T2。

  • 如果任意一个Server以T1、T2的顺序commit执行,其他所有的Server也必须以T1、T2的顺序执行。

“两段提交协议”最大的问题是如果Leader发送了PROPOSAL消息后crash或暂时失去连接,会导致整个集群处在一种不确定的状态(follower不知道该放弃这次提交还是执行提交)。Zookeeper这时会选出新的leader,请求处理也会移到新的leader上,不同的leader由不同的epoch标识。切换Leader时,需要解决下面两个问题:

1. Never forget delivered messages

Leader在COMMIT投递到任何一台follower之前crash,只有它自己commit了。新Leader必须保证这个事务也必须commit。

2. Let go of messages that are skipped

Leader产生某个proposal,但是在crash之前,没有follower看到这个proposal。该server恢复时,必须丢弃这个proposal。

Zookeeper会尽量保证不会同时有2个活动的Leader,因为2个不同的Leader会导致集群处在一种不一致的状态,所以Zab协议同时保证:

  • 在新的leader广播Transaction之前,先前Leader commit的Transaction都会先执行。

  • 在任意时刻,都不会有2个Server同时有法定人数(quorum)的支持者。
    这里的quorum是一半以上的Server数目,确切的说是有投票权力的Server(不包括Observer)。

总结

简单介绍了Zookeeper的基本原理,数据模型,Session,Watch机制,一致性保证,Leader Election,Leader和Follower的工作流程和Zab协议。

参考

《ZooKeeper—Distributed Process Coordination》 by FlavioJunqueira and Benjamin Reed http://zookeeper.apache.org/doc/trunk/zookeeperOver.html http://www.ibm.com/developerworks/cn/opensource/os-cn-zookeeper/index.html 《ZooKeeper的一致性算法赏析》https://my.oschina.net/pingpangkuangmo/blog/778927

你还有什么想要补充的吗?

PS:欢迎在留言区留下你的观点,一起讨论提高。如果今天的文章让你有新的启发,欢迎转发分享给更多人。


版权申明:内容来源网络,版权归原创者所有。除非无法确认,我们都会标明作者及出处,如有侵权烦请告知,我们会立即删除并表示歉意。谢谢!

欢迎加入后端架构师,在后台回复“”即可。

最近面试BAT,整理一份面试资料《Java面试BAT通关手册》,覆盖了Java核心技术、JVM、Java并发、SSM、微服务、数据库、数据结构等等。在这里,我为大家准备了一份2021年最新最全BAT等大厂Java面试经验总结。

别找了,想获取史上最简单的Java大厂面试题学习资料

扫下方二维码回复「面试」就好了

嘿,你在看吗

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
谷歌“宇宙级”突破惊呆马斯克!Willow芯片掀量子革命,5分钟吊打超级计算机

谷歌“宇宙级”突破惊呆马斯克!Willow芯片掀量子革命,5分钟吊打超级计算机

格隆汇
2024-12-10 15:22:43
没看走眼,076果然主桅杆上了雷达,舰体刷了漆,离下水舾装不远

没看走眼,076果然主桅杆上了雷达,舰体刷了漆,离下水舾装不远

暖心的小屋
2024-12-10 10:07:19
中超历史最强10大外援,保利尼奥第2,奥斯卡第3,第1实至名归!

中超历史最强10大外援,保利尼奥第2,奥斯卡第3,第1实至名归!

我就是一个说球的
2024-12-10 17:08:24
东体:奥斯卡预计很快暂别上海 日常生活中由孩子充当翻译

东体:奥斯卡预计很快暂别上海 日常生活中由孩子充当翻译

直播吧
2024-12-11 09:26:14
济南大学一食堂档口拒绝煮泡面涨价,被同行威胁后关门?学生投诉至市监局,校方回应

济南大学一食堂档口拒绝煮泡面涨价,被同行威胁后关门?学生投诉至市监局,校方回应

极目新闻
2024-12-10 17:10:46
“邪恶大鼠标”降到20万!国产新能源的天都塌了

“邪恶大鼠标”降到20万!国产新能源的天都塌了

少数派报告Report
2024-12-09 21:48:35
亚洲首艘迪士尼游轮开售:有过山车,3晚人均超5000元

亚洲首艘迪士尼游轮开售:有过山车,3晚人均超5000元

南方都市报
2024-12-10 22:17:09
新华社快讯:韩国警方对警察厅、首尔警察厅、国会警卫队展开扣押搜查

新华社快讯:韩国警方对警察厅、首尔警察厅、国会警卫队展开扣押搜查

参考消息
2024-12-11 11:02:06
85分钟遭绝杀!欧冠首支出局队诞生:6连败0分 最烂种子队

85分钟遭绝杀!欧冠首支出局队诞生:6连败0分 最烂种子队

叶青足球世界
2024-12-11 06:59:35
切尔诺贝利地下的危机:熄灭多年的熔毁炉芯,为何会被复燃?

切尔诺贝利地下的危机:熄灭多年的熔毁炉芯,为何会被复燃?

国学聚焦
2024-12-10 15:22:36
28岁郭麒麟低调现身黄璐家宴,31岁姜思达手持糖葫芦,打扮时髦!

28岁郭麒麟低调现身黄璐家宴,31岁姜思达手持糖葫芦,打扮时髦!

鑫鑫说说
2024-12-11 09:38:30
“全网最平胸大赛”飞机场妹子晒图展示,没想到一个比一个炸裂

“全网最平胸大赛”飞机场妹子晒图展示,没想到一个比一个炸裂

经典段子
2024-12-03 22:43:23
网传渤海银行年终奖“打骨折”,业绩连年萎靡下员工薪水下降、高层薪酬连升

网传渤海银行年终奖“打骨折”,业绩连年萎靡下员工薪水下降、高层薪酬连升

天天财经116
2024-12-10 17:52:16
这是我的一个小账户,持有两年,因为资金小,也懒得动它。

这是我的一个小账户,持有两年,因为资金小,也懒得动它。

人情皆文史
2024-11-11 00:02:54
队记:如果詹姆斯申请交易湖人会配合 而布朗尼必须参与交易其中

队记:如果詹姆斯申请交易湖人会配合 而布朗尼必须参与交易其中

直播吧
2024-12-11 09:48:18
金价三连涨,周大福、老凤祥等品牌金价突破810元

金价三连涨,周大福、老凤祥等品牌金价突破810元

澎湃新闻
2024-12-11 12:13:09
TikTok还剩39天极限自救

TikTok还剩39天极限自救

中国企业家杂志
2024-12-11 09:44:04
地狱无人机导弹首炸!布良斯克夜如昼,泽连斯基:下一站莫斯科

地狱无人机导弹首炸!布良斯克夜如昼,泽连斯基:下一站莫斯科

大风文字
2024-12-11 13:03:54
突然大涨,全球静待今晚!

突然大涨,全球静待今晚!

暴财经
2024-12-11 11:51:44
炒股,忘记价格太重要了,习惯了做T,那就一路t到底,不要因为价格而放弃了!

炒股,忘记价格太重要了,习惯了做T,那就一路t到底,不要因为价格而放弃了!

新浪财经
2024-11-11 09:20:15
2024-12-11 15:44:49
程序员小乐
程序员小乐
有趣有内涵
3163文章数 9504关注度
往期回顾 全部

健康要闻

花18万治疗阿尔茨海默病,值不值?

头条要闻

运营20年后养乐多关闭上海工厂 日销量曾高达760万瓶

头条要闻

运营20年后养乐多关闭上海工厂 日销量曾高达760万瓶

体育要闻

雷霆灭独行侠闯进四强 东契奇16+11

娱乐要闻

琼瑶遗体火化,儿子含泪送别母亲

财经要闻

TikTok还剩39天极限自救

科技要闻

谷歌宣布"突破性进展" 股价大涨5%

汽车要闻

高颜值高空间高乐趣 iCAR V23是懂年轻人的

态度原创

家居
房产
旅游
教育
军事航空

家居要闻

环抱大平层 神秘通透

房产要闻

秀英港搬迁,最新消息传出!海口湾业主,集体沸腾了!

旅游要闻

City fly 重庆低空游如何“出圈”

教育要闻

有道副总裁蒋叶光:孩子背古诗家长也得背! 以身作则才能激发孩子

军事要闻

以军称已摧毁叙利亚70%以上的军事力量

无障碍浏览 进入关怀版