Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >分布式面试题,ZK集群如何实现高可用部署?

分布式面试题,ZK集群如何实现高可用部署?

作者头像
用户5546570
发布于 2019-06-06 03:20:18
发布于 2019-06-06 03:20:18
1.9K0
举报

Zookeeper 我想大家都不陌生,在很多场合都听到它的名字。它是 Apache 的一个顶级项目,为分布式应用提供一致性高性能协调服务。可以用来做:配置维护、域名服务、分布式锁等。有很多开源组件,尤其是中间件领域,使用 Zookeeper 作为配置中心或者注册中心。它是 HadoopHBase 的重要组件,是 Kafka 的管理和协调服务,是 Dubbo 等服务框架的注册中心等。

原理

在介绍高可用部署前,我们先了解下 Zookeeper 的基本知识,这对充分理解它的高可用部署非常重要。

架构

下图是 Zookeeper 的架构图,ZooKeeper 集群中包含 Leader、Follower 以及 Observer 三个角色:

  • Leader:负责进行投票的发起和决议,更新系统状态,Leader 是由选举产生;
  • Follower: 用于接受客户端请求并向客户端返回结果,在选主过程中参与投票;
  • Observer:可以接受客户端连接,接受读写请求,写请求转发给 Leader,但 Observer 不参加投票过程,只同步 Leader 的状态,Observer 的目的是为了扩展系统,提高读取速度。

Client 是 Zookeeper 的客户端,请求发起方。

高可用

Zookeeper 系统中只要集群中存在超过一半的节点(这里指的是投票节点即非 Observer 节点)能够正常工作,那么整个集群就能够正常对外服务

基于此,如果想搭建一个能够允许 N 台机器 down 掉的集群,那么就要部署一个由 2*N+1 台服务器构成的 ZooKeeper 集群。

因此,如果部署了 3 个 Zookeeper 节点(非 Observer),则如果至少有 2个节点可用则整个集群就可用,意味着 1 个节点故障,不影响 Zookeeper 集群对外提供服务;如果部署了 5 个节点,意味着 2 个节点同时故障,Zookeeper 集群依然能够正常对外提供服务。

Zookeeper 集群部署的节点(非 Observer)数一般为奇数个

部署的节点数一般为奇数个,这里不是说不能为偶数个。例如如果部署了 4 个节点,这意味着需要 4/2+1 = 3 个节点正常,集群才能正常对外服务,即可以容忍 1 个节点故障,但是这个部署 3 个节点,其实效果是一样的,也就是说部署偶数个,从高可用方面来说只是浪费了 1 台机器而已。

部署

既然只要 Zookeeper 集群中存在超过一半的节点能够正常工作,集群就能够正常服务,那 Zookeeper 如果想要 Zookeeper 高可用岂不是很简单,是不是多部署几个节点不就好了呢?

多部署节点就高可用了?

多部署节点,貌似确实是能够增强可用性,但是这里还需要考虑以下两个问题:

  • 多增加节点对性能和写可用性有影响 增加节点,意味了能够容忍非正常节点数更多,听起来高可用是更高了。但是,节点数越多意味着 Leader 发出的提案需要更多的节点(半数以上)来接受提案,这必然增加提案 commit 的耗时,也就意味着对写请求的性能以及可用性影响比较大。因此,对于正常的业务系统来说需要完美的权衡利弊,来调整节点的个数。
  • 需要考虑容灾需求 部署还得结合容灾要求,需要能在机房故障,地区故障时整个 Zookeeper 集群是否能正常对外提供服务。

机房容灾

如果要保证在整个机房出现故障的情况下,保证 Zookeeper 集群的高可用,是要对 Zookeeper 做跨机房部署的。

单机房

我们先看下单机房部署情况下,下图是单个机房 5 个节点的部署情况。在单机房部署的情况下是不能做到机房容灾的,一旦机房出现问题,整个 Zookeeper 集群就不能对外工作。

单机房部署还需考虑所选的节点应该尽量不在同一个宿主机,不同机柜,避免多个节点同时出现问题。

同城双机房

既然单机房做不到机房容灾,那双机房呢?

如下图在“机房 1”部署 3 个节点,“机房 2”部署 2 个节点,总共 5 个节点的 Zookeeper 集群,这能做到机房容灾吗?任意一个机房故障,集群都能正常对外提供工作吗?

其实,还是不行的。假如“机房 2”故障,“机房 1”正常,这种情况下,因为“机房 1”存在 3 个节点,大于半数,因此还是能够正常工作的;但是,假如“机房 1”故障,那存活节点数只有 2 个,整个集群是不能正常工作的。

因此,Zookeeper 双机房部署,是不能够做到机房容灾的。

同城三机房

我们再来看看三机房部署,三机房部署,是能够做到机房容灾的。还是以 5 个节点的集群为例:

如下图,在“机房 1”、“机房 2”同时部署 2 个节点,而“机房 3” 部署 1 个节点。在任意一个机房故障的情况下,都能满足正常节点数大于半数及以上,所以能够保证机房容灾。

异地容灾

仅仅做到机房级别的容灾,对于一般的业务应该就够了,不过目前很多公司采用的是两地三中心模式,蚂蚁金服甚至做到了三地五中心。在这种情况下,我们的 Zookeeper 集群应该如何部署呢?

两地三中心

“两地三中心”即生产数据中心、同城灾备中心、异地灾备中心建设方案。这种模式下,两个城市的三个数据中心互联互通,如果一个数据中心发生故障或灾难,其他数据中心可以正常运行并对关键业务或全部业务实现接管。

在两地三中心的的模式下,Zookeeper 集群的部署有哪些考量呢?

如下图,一般两地三中心采用的是下面这种部署方式。在“地区 1”有两个同城数据中心,“中心 1”和“中心2”,在异地“地区 2” 有一个异地中心“中心 1”。这里你可能有两个疑问:

  • 为什么投票节点(Follower 和 Leader)都放在“地区 1 中心 1”,而不是按照三机房类似的方案在三个中心都进行部署呢?
  • 这里是因为由于异地之间的物理距离比较长,网络传输时延比较大,导致集群的投票节点的决策时间比较长,进而影响写性能。试想一下,如果两地选用的是北京和上海两座城市,走专线网络延时约 30ms,在写数据时,需要半数节点同意提案,一个写请求才能成功。因此,一次写成功的时间会比较长。 另外,异地之间的网络比较复杂,很容易出现集群重新选举,导致整个集群不可用,而且选举时间会比较长。 因此,一般只在一个中心内做到三机房部署,其他中心都是用 Observer 节点,可以看出,部署上 Zookeeper 集群无法做到异地容灾的。
  • 为什么引入了 Observer 节点?
  • Observer 能很好的对 Zookeeper 集群进行扩展,Observer 可以提供 Client 读写,但不参与投票。因此,Observer 节点对集群不影响投票耗时,也不影响集群选举。另外,加入 Observer 对读性能是一个很大的提升。

三中心优化

为了保护集群,在三个中心都部署上 Observer 节点,而 Client 只与 Observer 机点进行交互,用这种方式可以降低投票节点的工作负载,降低 Leader 和 Follower 的不稳定性,从而提高整个集群的稳定性和可用性。

总结

Zookeeper 的高可用在部署上也是有很多考量的,Zookeeper 集群在部署上可以做到机房容灾,但是做不到异地容灾。另外,为了提升集群的扩展性和稳定性,可以引入 Observer 节点,提升读性能,保护 Leader 与 Follower 节点。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019.05.21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
QQ AI画画|探索机器创造力
前言: 当我们谈论画作,会醉心于印象派光影斑斓的色彩,会惊叹于国风文人画如诗如歌的构图,会震撼于画师笔下一个又一个充满想象力和创造力的世界;而当我们提及AI,脑海中浮现的是前沿深奥的大数据云计算,是冰冷严谨的逻辑思维能力。两者碰撞交织,让AI学会“通感”,AI画手们带着惊人的机器想象力和极具冲击力的刻画刷新着我们的感官体验。与此同时居高不下的热点讨论也一遍遍提出质疑:AI让艺术沦为了单纯的数据游戏,使绘画失去了灵魂。那么如何为AI创造力赋能,将其转化为视觉传达的生产力,成为设计师探索的新方向。 AI画画结
腾讯ISUX
2023/02/13
1.3K0
QQ AI画画|探索机器创造力
狂徒AI对罗翔老师下手了
金磊 发自 凹非寺 量子位 | 公众号 QbitAI 朋友,有没有想过自己在二次元里长什么样? 最近就有这么样的一个生成器在国内外火了。 瞧,输一张罗翔老师的照片,“啪的一下”就能生成二次元漫画风: 一键秒变霸道总裁有木有,引得网友纷纷前来围观。 甚至就连KFC(肯德基)官方账号都来凑起了热闹,亲自打破自家老爷子的次元壁: 各类梗图更是层出不穷: 在二次元滤镜下,就连这张经典的“女人吼猫”都透露出一丝温馨,“竟然都有点可爱了呢”。 这就是QQ小世界在近期推出的二次元形象生成器——“异次元的我”。 那么
量子位
2023/02/28
3020
狂徒AI对罗翔老师下手了
我迟早被这些AI绘画笑死
詹士 发自 凹非寺 量子位 | 公众号 QbitAI AI绘画,你没事吧? 狗主人直接变身狗爸爸,被顶上APP首页: 纯欲风女孩变成了纯欲风猴子…… 下方网友评价「当真是二次猿模型」: 甚至,还有结婚照男主角变成墙上大头贴,配着粉色花瓣,画风十分阴间…… 这些例子来自各平台用户们的分享,这两天,又掀起一波「AI绘画离谱作品」的讨论。 抖音热榜上,该话题流量超660万,阿根廷足球队也甘拜下风。 连无穷小亮也在网上吐槽「AI智障绘画」,引来大批围观: 离谱的AI绘画背后,是时下AIGC门槛一再降低,近
量子位
2023/02/28
1.2K0
我迟早被这些AI绘画笑死
QQ动漫丨高效与趣味的有机融合
项目背景 随着网络的持续提速和优质国漫的不断兴起,动漫在年轻人的生活中,已经成为了他们日常不可或缺的一部分。为了更好地为QQ当中的海量年轻用户提供服务,我们也想借着产品这次想更纯粹化的契机,对QQ动漫的品牌和体验进行一次全面的升级改造。 PART1 目标定义 通过前期的分析体验,我们梳理出目前产品存在的一些核心问题。 而从用研和报告发现,我们的目标用户主要是小学高年级以及初高中生。从调研中我们了解到他们日常使用的上网设备主要是以中低端机型为主,而用于娱乐消费的时间一般也是比较有限且固定的,所以
腾讯ISUX
2021/05/14
6300
DNSPod十问周艺超:AI如何成为当代毕加索?
本期嘉宾 周艺超 腾讯QQ影像中心工程师 周艺超,腾讯QQ影像中心资深应用开发工程师。入职腾讯后负责超级QQ秀的智能捏脸相关的研发工作,2022年开始负责小世界AIGC相关的技术研发和产品落地,主要负责《异次元的我》、《魔法画室》等活动的算法开发、工具架构搭建、AI应用落地等相关工作。加入腾讯前从事虚拟人生成、人脸编辑等领域相关研究。 主持人 田超 腾讯云企业中心总经理 田超,腾讯云企业中心总经理、音视频应用平台总经理,负责腾讯云用户增长、DNSPod业务以及企业应用相关产品。同时也是资深用户增长专
腾讯云DNSPod团队
2023/04/23
7490
DNSPod十问周艺超:AI如何成为当代毕加索?
AI+漫画生产 小冰、百度们的新商机?
近年,由于网络的普及,动漫作品传播的速度不断加快,二次元文化的受众数量不断上升,影响范围也越来越广泛。
用户2908108
2021/04/26
9090
AI+漫画生产 小冰、百度们的新商机?
理所当燃 | 打造会员20周年超燃盛典
项目背景 2000年QQ会员诞生,不断探索如何带给用户更好的增值服务,正值20周年的时间节点,QQ会员推出20周年系列庆典活动,携手靓号、会员游戏、个性化装扮、QQ音乐、bilibili等多个分会场,通过多种好礼折扣、豪华大礼包等联合回馈用户,和广大QQ用户一起携手为QQ会员20周年庆生。 整个项目主要从以下六个部分进行规划:概念脑暴、品牌重塑、主活动(portal聚合、QQ能量值等)、设计衍生、外部联动、庆典宣传等。通过系统有节奏的整体规划,设计团队一步一步建立会员20周年品牌,体系化的构建以“渠
腾讯ISUX
2021/05/26
1.4K0
刷屏朋友圈的QQ小世界二次元生成器原理解密
作者:yichaozhou,腾讯 PCG 应用研究员 只需要上传一张照片,一键即可穿越二次元。火遍国内外的 QQ 小世界二次元生成器——“异次元的我“背后原理解密。 1 项目介绍 今年是人工智能领域成果井喷的一年,前有 AI 画画后有 chatGPT,纷纷迅速走红网络。早在今年五月,QQ 影像中心推出的国内第一款基于 AI 画画技术的”AI 恋爱专属画”520 活动就在小世界走红,最近新推出的“异次元的我”二次元形象生成器更是火遍国内外。 你可以看到罗翔老师一键变身霸道总裁: 甚至能看到 KFC 官推亲自
腾讯技术工程官方号
2022/12/26
1.2K0
刷屏朋友圈的QQ小世界二次元生成器原理解密
2022年全网最全AI绘画产品整理(一共23款,免费的绘画次数用到你手软)
完全够普通人到日常绘画需求;如果你有大量的绘画需求(月绘画次数过万),欢迎联系(关注公众号:飞链云3D数字生态),提供专门的开放平台API接口对接,基于我们研发能力和算法的提升,我们价格可低至6分一次(市场价格通常在1毛-2毛不等);专业阿里系研发团队,日承载绘画次数可达百万次;
谙忆
2023/01/30
3.6K0
邂逅二次元爱豆 | 波洞星战设定
腾讯ISUX isux.tencent.com 社交用户体验设计 导语 在ACG圈有着这样一种赛事:没有硝烟战火,没有(广义上的)明星参与,没有盛大线下比拼,却能引发广大粉丝疯狂参与,甚至爆肝应援——这就是「萌战」,属于二次元粉丝和人气动漫角色的评选大战。此类活动鼻祖是「日萌」,起源于日本最大的论坛2ch,从02年开始流传至今,由网站居民自发举行,选出年度二次元er最爱的人气角色。因赛制问题和不接受非本国人员投票等原因慢慢失去关注,而后「世萌」、「燃战」以及国内的「B萌」「部落萌」等等
腾讯ISUX
2019/10/10
6870
邂逅二次元爱豆 | 波洞星战设定
微视品牌体验设计
腾讯ISUX isux.tencent.com 社交用户体验设计 项目背景 2017年是整个短视频大爆发的时期,内容产业逐渐成为移动互联网新的生力军。短视频产品同质化,用户体验趋同,团队希望运用品牌体验的全局设计思维,从视觉识别,用户体验,线上线下推广及产品礼品等多个维度来凸显产品核心价值,搭建一套完整统一的产品设计语言。 目标 微视目标很清晰,需要在短时间内快速进入短视频第一集团,切入短视频社交领域,挖掘更多机会点,也希望借这个机会能成为像微信这样的腾讯战略级产品。 设计挑战 设计的挑战
腾讯ISUX
2018/10/17
1.3K0
微视品牌体验设计
韩国最新「美女元宇宙」引爆Reddit!最强换脸神器美女自拍一键转漫画
最近,韩国最大的漫画平台网站Naver webtoon(네이버만화)推出了一个新工具WebtoonMe,可以将自拍照或者视频转换为韩式网络漫画的风格。
新智元
2022/02/24
1.5K0
韩国最新「美女元宇宙」引爆Reddit!最强换脸神器美女自拍一键转漫画
VIP品牌升级 | 打造有温度的二次元形象
一、项目背景 随着80、90、00后陆续成为互联网社交的主力群体,泛二次元文化从以前的小众圈层,逐渐发展壮大,与主流文化接轨。据多个专业数据分析机构的报告显示,国内泛二次元用户规模已达3亿+人。为了精准触达用户,黄钻、QQ会员以及QQ大会员陆续推出了全新的二次元IP,并在系列营销活动中崭露头角。 二、策略定位 综合考虑品牌调性和营销策略,三大品牌的新形象定位为“二次元Q版拟人”风格。 我们的用户群与泛二次元用户有很大交集,二次元风格正好适配我们目标人群的兴趣点,有助于提升三大品牌在目标群体间的好
腾讯ISUX
2021/12/07
8790
ISUX「七月」行业设计趋势速递
本期摘要: (1)Facebook 开始在美测试NFT功能(2)Facebook Groups 引入频道功能 (3)Niantic 正式推出社交应用 Campfire(4)twitter 内测多人共同编辑一条tweet的能力(5)Instagram Reels 短视频功能更新(6)QQ音乐打造音乐版社交元宇宙(7)Meta Horizon Home 让 VR 更具社交性(8)抖音上线桌面端(9)“中文梗博物馆”出现在 VR 世界(10)#Me:现实社交带进异世界的虚拟游戏(11)上大元宇宙:现实校园搬上虚拟
腾讯ISUX
2022/08/26
9480
ISUX「七月」行业设计趋势速递
AI绘画社区:解锁艺术共创的无限可能(9/10)
在科技飞速发展的今天,AI 绘画早已不再仅仅是一项孤立的技术,它正以惊人的速度融入我们的社交生活,成为艺术爱好者们交流互动的全新方式,构建起一个充满活力与创意的社交生态。
正在走向自律
2025/02/09
2150
AI绘画社区:解锁艺术共创的无限可能(9/10)
原来最强赘婿在二次元长这样,秒穿次元壁的AI特效又双叒火了
虽然每天早晨甚至无法从50平米的地铺上醒来,但偶尔刷刷知乎,还是会被这类问题吸引住眼球——
量子位
2020/09/30
4910
原来最强赘婿在二次元长这样,秒穿次元壁的AI特效又双叒火了
QTX看点 | 企鹅巨械QQ MAX BOT横空出世!
Pat Lee专访 在Marvel或DC漫画改编的电影里,总有类似的场景:一个看似路人般的男子,他们或借助神力、或借助科技,最后拥有强大的力量。 最终惩恶扬善,拯救世界。 超级英雄电影之所以风靡世界,究其原因——是大部分普通人心中,都有一个拯救世界的梦想。超级英雄让普通人的梦想实现在虚拟的电影世界里。 最近,激萌可爱的QQ就试着拯救了一次世界。人们眼中一直萌哒哒的QQ,其实也可以充满战斗力! 还有个惊喜哟!这款企鹅巨械的潮玩将在QQ潮玩展预售,同款3米的巨型雕塑也将同时亮相!真的别错过!感兴趣的
腾讯ISUX
2020/08/26
1.4K0
AI绘画进阶指南:突破参数与模型的次元壁(8/10)
在 AI 绘画的奇妙世界里,许多人最初被其神奇效果吸引,凭借简单指令就能生成有趣图像,从而踏入这片充满创意的领域。从最初惊叹于 AI 绘画工具能将简单的文字描述转化为一幅幅精美的图像,到逐渐不满足于基础操作,想要突破瓶颈,从新手成长为高手,这中间的进阶之路充满了挑战与惊喜。
正在走向自律
2025/02/09
2680
AI绘画进阶指南:突破参数与模型的次元壁(8/10)
开源神器:想秒变二次元?行,满足你!
当然,如果你有喜欢的二次元老婆,想看她穿越到现实会是什么样子,也没有问题。只要输入一张她的头像:
GitHubDaily
2019/11/06
1.4K0
开源神器:想秒变二次元?行,满足你!
【犀牛鸟·视野】SIGGRAPH ASIA 2018:腾讯“AI画师YUI”的背后技术
导语 腾讯AI Lab在SIGGRAPH ASIA 2018上展出了自主研发的“AI画师YUI”demo。访客可以直接用手机拍摄一张自己的照片,然后利用AI画师YUI的微信小程序自动将真人头像转换成萌萌的日系二次元头像。转换结果可以现场打印成照片,供访客带回家留念。很多访客都亲身试用了该功能,表示非常有趣,期待着未来的正式上线。 图1 SIGGRAPH AISA上现场展示AI画师YUI YUI 的日文假名写法为“ゆい”,对应汉字为“結”(简体中文:结),其意思即“连结”。其名字的寓意是希望 Y
腾讯高校合作
2018/12/19
1.3K0
【犀牛鸟·视野】SIGGRAPH ASIA 2018:腾讯“AI画师YUI”的背后技术
推荐阅读
相关推荐
QQ AI画画|探索机器创造力
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档