安庆大理运城常德铜陵江西
投稿投诉
江西南阳
嘉兴昆明
铜陵滨州
广东西昌
常德梅州
兰州阳江
运城金华
广西萍乡
大理重庆
诸暨泉州
安庆南充
武汉辽宁

Redis哨兵机制原理浅析

10月6日 六壬会投稿
  一、前言
  上一篇文章Redis主从复制原理中简要地说明了主从复制的一个基本原理,包含全量复制、复制积压缓冲区与增量复制等内容,有兴趣的同学可以先看下。
  利用主从复制,可以实现读写分离、数据备份等功能。但如果主库宕机后,需要运维人员手动地将一个从库提升为新主库,并将其他从库slaveof新主库,以此来实现故障恢复。
  因此,主从模式的一个缺点,就在于无法实现自动化地故障恢复。Redis后来引入了哨兵机制,哨兵机制大大提升了系统的高可用性。二、什么是哨兵
  哨兵,就是站岗放哨的,时刻监控周围的一举一动,在第一时间发现敌情并发出及时的警报。
  Redis中的哨兵(Sentinel),则是一个特殊的Redis实例,不过它并不存储数据。也就是说,哨兵在启动时,不会去加载RDB文件。
  关于Redis的持久化,可以参考我的另外一篇文章谈谈Redis的持久化AOF日志与RDB快照
  上图就是一个典型的哨兵架构,由数据节点与哨兵节点构成,通常会部署多个哨兵节点。
  哨兵主要具有三个作用,监控、选主与通知。
  监控:哨兵会利用心跳机制,周期性不断地检测主库与从库的存活性
  选主:哨兵检测到主库宕机后,选择一个从库将之切换为新主库
  通知:哨兵会将新主库的地址通知到所有从库,使得所有从库与旧主库slaveof新主库,也会将新主库的地址通知到客户端上
  我会在下文详细讲一下监控与选主的过程三、监控
  哨兵系统是通过3个定时任务,来完成对主库、从库与哨兵之间的探活。哨兵如何拿到从库地址
  首先我们会在配置文件中配置主库地址,这样哨兵在启动后,会以每隔10秒的频率向主库发送info命令,从而获得当前的主从拓扑关系,这样就拿到了所有从库的地址。哨兵如何感知到其他哨兵的存在
  接着每隔2秒,会使用pubsub(发布订阅)机制,在主库上的sentinel:hello的频道上发布消息,消息内容包括哨兵自己的ip、port、runid与主库的配置。
  每个哨兵都会订阅该频道,在该频道上发布与消费消息,从而实现哨兵之间的互相感知。哨兵是如何实现对节点的监控
  利用启动配置与info命令可以获取到主从库地址,利用发布订阅可以感知到其余的哨兵节点。
  在此基础上,哨兵会每隔1秒向主库、从库与其他哨兵节点发送PING命令,因此来进行互相探活。主观下线与客观下线
  当某个哨兵在downaftermilliseconds(默认是30秒)配置的连续时间内,仍然没有收到主库的正确响应,则当前哨兵会认为主库主观下线,并将其标记为sdown(subjectivedown)
  为了避免当前哨兵对主库的误判,因此这个时候还需要参考其他哨兵的意见。
  接着当前哨兵会向其他哨兵发送sentinelismasterdownbyaddr命令,如果有半数以上(由quorum参数决定)的哨兵认为主库确实处于主观下线状态,则当前哨兵认为主库客观下线,标记为odown(objectivedown)四、选主
  一旦某个主库被认定为客观下线时,这个时候需要进行哨兵选举,选举出一个领导者哨兵,来完成主从切换的过程。哨兵选举
  哨兵A在向其他哨兵发送sentinelismasterdownbyaddr命令时,同时要求其他哨兵同意将其设置为Leader,也就是想获得其他哨兵的投票。
  在每一轮选举中,每个哨兵仅有一票。投票遵循先来先到的原则,如果某个哨兵没有投给别人,就会投给哨兵A。
  首先获得半数以上投票的哨兵,将被选举称为Leader。
  这里的哨兵选举,采用的是Raft算法。这里不对Raft做详细的探讨,有兴趣的同学,可以参考我的另外一篇文章22张图,带你入门分布式一致性算法Raft
  该文章采用大量的图例,相信你可以从中学习到全新的知识,从而打开分布式一致性算法的大门,大伙们记得等我搞完Paxos与Zab。
  过半投票机制也常用于很多算法中,例如RedLock,在半数以上的节点上加锁成功,才代表申请到了分布式锁,具体可参考这篇文章的最后我用了上万字,走了一遍Redis实现分布式锁的坎坷之路,从单机到主从再到多实例,原来会发生这么多的问题
  在Zookeeper选举中,同样也用到了过半投票机制,在这篇文章中面试官:能给我画个Zookeeper选举的图吗?我从源码角度分析了Zookeeper选举的过程。故障恢复
  在选举到领导者哨兵后,将由该哨兵完成故障恢复工作。
  故障恢复分为以下两步:首先需要在各个从库中,选出一个健康的且数据最新的从库出来。将该从库提升为新主库,即执行slaveofnoone,其他从节点slaveof新主库。
  详细说一下第一步,挑选是有条件的。首先要过滤出不健康的节点,再按某种规则排序,最后取第一个从库,我们直接从源码入手:sentinelRedisInstancesentinelSelectSlave(sentinelRedisInstancemaster){sentinelRedisInstanceinstancezmalloc(sizeof(instance〔0〕)dictSize(masterslaves));sentinelRedisInstanceselectedNULL;intinstances0;mstimetmaxmasterdowntime0;if(masterflagsSRISDOWN)maxmasterdowntimemstime()maxmasterdowntimemasterdownafterperiod10;didictGetIterator(masterslaves);while((dedictNext(di))!NULL){sentinelRedisInstanceslavedictGetVal(de);处于主观下线与客观下线的状态if(slaveflags(SRISDOWNSRIODOWN))断开连接if(slavelinkdisconnected)5秒内没有回应哨兵的ping命令if(mstime()slavelinklastavailtimeSENTINELPINGPERIOD5)优先级为0if(slaveslavepriority0)没在3秒或5秒(依据主库状态)内完成对info命令的回应if(mstime()slaveinforefreshinfovaliditytime)与主库的断开时间,超过maxmasterdowntimeif(slavemasterlinkdowntimemaxmasterdowntime)健康的节点加入到instance数组中instance〔instances〕}按照某种规则进行快速排序qsort(instance,instances,sizeof(sentinelRedisInstance),compareSlavesForPromotion);选取第一个selectedinstance〔0〕;}intcompareSlavesForPromotion(constvoida,constvoidb){sentinelRedisInstancesa(sentinelRedisInstance)a,sb(sentinelRedisInstance)b;charsarunid,首先比较优先级,谁的优先级越小(除了0),就选谁if((sa)slavepriority!(sb)slavepriority)return(sa)slavepriority(sb)当优先级一样时,比较复制偏移量。谁的偏移量大,就选谁if((sa)slavereploffset(sb)slavereploffset){return1;ab}elseif((sa)slavereploffset(sb)slavereploffset){return1;ab}优先级与复制偏移量一致时,比较runidsarunid(sa)sbrunid(sb)低版本的Redis,在info命令中不存在runid,因此可能为null为null的runid,认为它比任何runid都大if(sarunidNULLsbrunidNULL)return0;elseif(sarunidNULL)return1;abelseif(sbrunidNULL)return1;ab按照字母顺序排序,谁靠前,则选谁returnstrcasecmp(sarunid,sbrunid);}
  因此,以下从库会被过滤出:主观下线、客观下线或断线没在5秒内完成对哨兵ping命令的回应priority0没在3秒或5秒内(由主库状态决定)内完成对info命令的回应与主库的断开时间,超过maxmasterdowntime
  剩下的节点,就是健康的节点,此时再执行一次快速排序,排序的规则如下:比较优先级(priority),谁的优先级越小(除了0),就选谁比较复制偏移量。谁的偏移量大,就选谁比较runid,按照字母顺序排序。谁靠前,则选谁五、总结
  本文算是Redis哨兵的一个入门文章,主要讲了哨兵的作用,例如监控、选主和通知。
  在Redis读写分离的情况下,使用哨兵可以很轻松地做到故障恢复,提升了整体的可用性。
  但哨兵无法解决Redis单机写的瓶颈,这就需要引入集群模式,相应的文章也被列为明年的写作计划中。
投诉 评论 转载

21世纪产生的22个总冠军球队实力排名2017年勇士第一,雄自2000年以来,截止到2021年,一共产生了22个总冠军。这里面有不少球队不止一次夺冠,但是不同球队夺冠的实力,以及同一支球队在不同年份夺冠的实力都不相同。如何对这22……差异化推广有多重要,淘宝京东都知道随着行业竞争越发的激烈,同类产品也越来越多,而消费者在选择时也只会从他记忆深刻的几个品牌中去挑选。市场信息越多,人们能记住的品牌就越来越少,最后或许只有某一个品类的领导品牌。……5年1。7亿!与其交易杜兰特,不如梭哈超级状元,勇士得到他更金州勇士队是202122赛季的NBA总冠军球队,他们拥有一套多核心的夺冠体系,库里、克莱汤普森、威金斯、乔丹普尔和追梦格林等人都算是核心。但是,勇士队现在也有一些烦恼:威金斯和……广东队为何痛失CBA总冠军?韩德君说出大实话,杨鸣也没说错众所周知,本赛季的CBA总冠军由辽宁队夺得,而广东队在此前则是很遗憾失掉总冠军的争夺资格。对于双方球队的球员包括他们的球迷来说,应该都有着不一样的心情。对于广东队来说,在……周末F1伊莫拉大奖赛展望本周F1来到了伊莫拉大奖赛(4。224。24),现在叫做艾米利亚大奖赛。先说一下比赛时间:一练周五19:3020:30排位赛周五23:0000:00二练周六1……Redis哨兵机制原理浅析一、前言上一篇文章Redis主从复制原理中简要地说明了主从复制的一个基本原理,包含全量复制、复制积压缓冲区与增量复制等内容,有兴趣的同学可以先看下。利用主从复制,可……未来厨房长什么样老板电器副总裁何亚东日前接受采访时表示,在未来的中国新厨房里,运用数字智能化的烹饪方式,人人都可以成为烹饪创造者。越来越多的当代年轻人,将会用烹饪创造健康、创造美味、创造美好的……01!世界第2出局,第87分钟遭绝杀,中国女足有望一雪前耻正文2022哥斯达黎加U20女足世界杯正愈演愈烈,小组赛三场较量近日全部落下帷幕,世界排名第2的德国队01、01爆出两场超级大冷门,因此德国队以1胜2负的耻辱战绩小组赛彻……小米12彻底凉了!2300入手开启清仓模式自从小米12S发布后,小米12的价格便一降再降,在面对性能更好、性价比更高的小米12S时,小米12毫无性价比可言。可能小米也意识到了这一点,如果不讲价处理,不仅占库存而且价格只……最强23号,是篮球之神还是小皇帝篮球场上的23号球衣,被赋予了不一般的定义,如果实力不够超群,都没有底气穿这件球衣。23号球衣代表着伟大,赋予这份伟大的人物是迈克尔乔丹,后来因为詹姆斯的横空出世,把23号推向……沈梓捷要后悔了!曝贺希宁受辱骂后或离队,下家已备好顶薪在此前14决赛,因为深圳队这边表现不好,最终0:2输给了上海队,无缘半决赛的争夺。而回顾这两场比赛可以发现,本身深圳队输给上海队主要的原因就是因为两个核心发生内讧,导致影……仙女都不怕冷的吗?孙芸芸好冷但是穿短裤,陶晶莹你真的好会近几日不但爆冷、还下雨下到几乎让人心情发霉的状态,但台湾省第一名媛孙芸芸硬是po文写了好冷但我穿短裤,以香奈儿长版军绿色外套搭配短裤,相当芸芸风格,网友也留言问她:仙女都是不怕……
祝绪丹素颜走机场,淡蓝色针织衫配老爹裤,甜美清新像邻家妹妹吗网传韩东君陈瑶再度合作,古装探案剧风月锦囊将拍,期待五一劳动节图片配图高清大全,五一文案祝福语说说句子王晶罕携妻女出席活动,妻子气质出众,33岁爱女长相甜美似妈妈香味藏不住!江口牛干巴制作现场20生活秘诀,过上幸福非凡的生活互联网王者,现实只是懦夫!陆左亲自下场怒喷狂魔哥是小丑北京国安解释弃赛原因俱乐部仅5人身体健康,可参赛球员严重不足70年代供销社经常断销白酒,如今有的已绝版,快看看你喝过几款继回来的女儿后,迷雾剧场又推出四部大剧,有你期待的吗?省钱小技巧,学会不再花冤枉钱钟欣潼和蔡卓妍组合22年后,两个人的选择截然不同《红岩》第二十三章读书笔记分享科目三雾天行驶开什么灯早起两不要,睡前三不宜,老辈人的告诫,别当耳旁风建议:夏天宝宝不爱喝水怎么办?恋爱15年如傀儡,和冯柯离婚不到4年,张靓颖彻底放飞自我自动化技术在机械设计制造中的应用研究由眼睛的构造解读一个人的运势和性格闭环分享糖友装闭环后血糖现如何?进入一览其搭建经历大地回春严防境外输入“生根发芽”如何训练狗狗不再晕车2021留守儿童工作计划精选三篇小旅行护发计划3天不洗头也不出油

友情链接:中准网聚热点快百科快传网快生活快软网快好知文好找七猫云易事利