游戏电视苹果数码历史美丽
投稿投诉
美丽时装
彩妆资讯
历史明星
乐活安卓
数码常识
驾车健康
苹果问答
网络发型
电视车载
室内电影
游戏科学
音乐整形

美团二面为什么Redis会有哨兵?

  话不多说,发车发车!
  提纲为什么要有哨兵机制?
  在Redis的主从架构中,由于主从模式是读写分离的,如果主节点(master)挂了,那么将没有主节点来服务客户端的写操作请求,也没有主节点给从节点(slave)进行数据同步了。
  主节点挂了
  这时如果要恢复服务的话,需要人工介入,选择一个从节点切换为主节点,然后让其他从节点指向新的主节点,同时还需要通知上游那些连接Redis主节点的客户端,将其配置中的主节点IP地址更新为新主节点的IP地址。
  这样也不太智能了,要是有一个节点能监控主节点的状态,当发现主节点挂了,它自动将一个从节点切换为主节点的话,那么可以节省我们很多事情啊!
  Redis在2。8版本以后提供的哨兵(Sentinel)机制,它的作用是实现主从节点故障转移。它会监测主节点是否存活,如果发现主节点挂了,它就会选举一个从节点切换为主节点,并且把新主节点的相关信息通知给从节点和客户端。哨兵机制是如何工作的?
  哨兵其实是一个运行在特殊模式下的Redis进程,所以它也是一个节点。从哨兵这个名字也可以看得出来,它相当于是观察者节点,观察的对象是主从节点。
  当然,它不仅仅是观察那么简单,在它观察到有异常的状况下,会做出一些动作,来修复异常状态。
  哨兵节点主要负责三件事情:监控、选主、通知。
  哨兵的职责
  所以,我们重点要学习这三件事情:哨兵节点是如何监控节点的?又是如何判断主节点是否真的故障了?根据什么规则选择一个从节点切换为主节点?怎么把新主节点的相关信息通知给从节点和客户端呢?如何判断主节点真的故障了?
  哨兵会周期性地给所有主从节点发送PING命令,当主从节点收到PING命令后,会发送一个响应命令给哨兵,这样就可以判断它们是否在正常运行。
  哨兵监控主从节点
  如果主节点或者从节点没有在规定的时间内响应哨兵的PING命令,哨兵就会将它们标记为主观下线。这个规定的时间是配置项downaftermilliseconds参数设定的,单位是毫秒。
  主观下线?难道还有客观下线?
  是的没错,客观下线只适用于主节点。
  之所以针对主节点设计主观下线和客观下线两个状态,是因为有可能主节点其实并没有故障,可能只是因为主节点的系统压力比较大或者网络发送了拥塞,导致主节点没有在规定时间内响应哨兵的PING命令。
  所以,为了减少误判的情况,哨兵在部署的时候不会只部署一个节点,而是用多个节点部署成哨兵集群(最少需要三台机器来部署哨兵集群),通过多个哨兵节点一起判断,就可以就可以避免单个哨兵因为自身网络状况不好,而误判主节点下线的情况。同时,多个哨兵的网络同时不稳定的概率较小,由它们一起做决策,误判率也能降低。
  具体是怎么判定主节点为客观下线的呢?
  当一个哨兵判断主节点为主观下线后,就会向其他哨兵发起命令,其他哨兵收到这个命令后,就会根据自身和主节点的网络状况,做出赞成投票或者拒绝投票的响应。
  当这个哨兵的赞同票数达到哨兵配置文件中的quorum配置项设定的值后,这时主节点就会被该哨兵标记为客观下线。
  例如,现在有3个哨兵,quorum配置的是2,那么一个哨兵需要2张赞成票,就可以标记主节点为客观下线了。这2张赞成票包括哨兵自己的一张赞成票和另外两个哨兵的赞成票。
  PS:quorum的值一般设置为哨兵个数的二分之一加1,例如3个哨兵就设置2。
  哨兵判断完主节点客观下线后,哨兵就要开始在多个从节点中,选出一个从节点来做新主节点。如何选新主节点?
  那么多从节点,到底选择哪个从节点作为新主节点的?
  随机的方式好吗?随机的方式,实现起来很简单,但是如果选到一个网络状态不好的从节点作为新主节点,那么可能在将来不久又要做一次主从故障迁移。
  所以,我们首先要把网络状态不好的从节点给过滤掉。首先把已经下线的从节点过滤掉,然后把以往网络连接状态不好的从节点也给过滤掉。
  怎么判断从节点之前的网络连接状态不好呢?
  Redis有个叫downaftermilliseconds10配置项,其downaftermilliseconds是主从节点断连的最大连接超时时间。如果在downaftermilliseconds毫秒内,主从节点都没有通过网络联系上,我们就可以认为主从节点断连了。如果发生断连的次数超过了10次,就说明这个从节点的网络状况不好,不适合作为新主节点。
  至此,我们就把网络状态不好的从节点过滤掉了,接下来要对所有从节点进行三轮考察:优先级、复制进度、ID号。在进行每一轮考察的时候,哪个从节点优先胜出,就选择其作为新主节点。第一轮考察:哨兵首先会根据从节点的优先级来进行排序,优先级越小排名越靠前,第二轮考察:如果优先级相同,则查看复制的下标,哪个从主节点接收的复制数据多,哪个就靠前。第三轮考察:如果优先级和下标都相同,就选择从节点ID较小的那个。第一轮考察:优先级最高的从节点胜出
  Redis有个叫slavepriority配置项,可以给从节点设置优先级。
  每一台从节点的服务器配置不一定是相同的,我们可以根据服务器性能配置来设置从节点的优先级。
  比如,如果A从节点的物理内存是所有从节点中最大的,那么我们可以把A从节点的优先级设置成最高。这样当哨兵进行第一轮考虑的时候,优先级最高的A从节点就会优先胜出,于是就会成为新主节点。第二轮考察:复制进度最靠前的从节点胜出
  如果在第一轮考察中,发现优先级最高的从节点有两个,那么就会进行第二轮考察,比较两个从节点哪个复制进度。
  什么是复制进度?主从架构中,主节点会将写操作同步给从节点,在这个过程中,主节点会用masterreploffset记录当前的最新写操作在replbacklogbuffer中的位置,而从节点会用slavereploffset这个值记录当前的复制进度。
  如果某个从节点的slavereploffset最接近masterreploffset,说明它的复制进度是最靠前的,于是就可以将它选为新主节点。第三轮考察:ID号小的从节点胜出
  如果在第二轮考察中,发现有两个从节点优先级和复制进度都是一样的,那么就会进行第三轮考察,比较两个从节点的ID号,ID号小的从节点胜出。
  什么是ID号?每个从节点都有一个编号,这个编号就是ID号,是用来唯一标识从节点的。
  到这里,选主的事情终于结束了。简单给大家总结下:过滤掉已经离线的从节点;过滤掉历史网络连接状态不好的从节点;将剩下的从节点,进行三轮考察:优先级、复制进度、ID号。在每一轮考察过程中,如果找到了一个胜出的从节点,就将其作为新主节点。由哪个哨兵进行主从故障转移?
  前面说过,为了更加客观的判断主节点故障了,一般不会只由单个哨兵的检测结果来判断,而是多个哨兵一起判断,这样可以减少误判概率,所以哨兵是以哨兵集群的方式存在的。
  那在选定了即将作为主节点的从节后,由哨兵集群中的哪个节点进行主从故障转移呢?
  所以这时候,还需要在哨兵集群中选出一个leeder,让Leader来执行主从切换。
  选举leeder的过程其实是一个投票的过程,在投票开始前,肯定得有个候选者。
  那谁来作为候选者呢?
  哪个哨兵节点判断主节点为客观下线,这个哨兵节点就是候选者,所谓的候选者就是想当Leader的哨兵。
  举个例子,假设有三个哨兵。当哨兵A先判断到主节点主观下线后,就会给其他实例发送ismasterdownbyaddr命令。接着,其他哨兵会根据自己和主节点的网络连接情况,做出赞成投票或者拒绝投票的响应。
  当哨兵A收到赞成票数达到哨兵配置文件中的quorum配置项设定的值后,就会将主节点标记为客观下线,此时的哨兵A就是一个Leader候选者。
  候选者如何选举成为Leader?
  候选者会向其他哨兵发送命令,表明希望成为Leader来执行主从切换,并让所有其他哨兵对它进行投票。
  每个哨兵只有一次投票机会,如果用完后就不能参与投票了,可以投给自己或投给别人,但是只有候选者才能把票投给自己。
  那么在投票过程中,任何一个候选者,要满足两个条件:第一,拿到半数以上的赞成票;第二,拿到的票数同时还需要大于等于哨兵配置文件中的quorum值。
  举个例子,假设哨兵节点有3个,quorum设置为2,那么任何一个想成为Leader的哨兵只要拿到2张赞成票,就可以选举成功了。如果没有满足条件,就需要重新进行选举。
  这时候有的同学就会问了,如果某个时间点,刚好有两个哨兵节点判断到主节点为客观下线,那这时不就有两个候选者了?这时该如何决定谁是Leader呢?
  每位候选者都会先给自己投一票,然后向其他哨兵发起投票请求。如果投票者先收到候选者A的投票请求,就会先投票给它,如果投票者用完投票机会后,收到候选者B的投票请求后,就会拒绝投票。这时,候选者A先满足了上面的那两个条件,所以候选者A就会被选举为Leader。
  为什么哨兵节点至少要有3个?
  如果哨兵集群中只有2个哨兵节点,此时如果一个哨兵想要成功成为Leader,必须获得2票,而不是1票。
  所以,如果哨兵集群中有个哨兵挂掉了,那么就只剩一个哨兵了,如果这个哨兵想要成为Leader,这时票数就没办法达到2票,就无法成功成为Leader,这时是无法进行主从节点切换的。
  因此,通常我们至少会配置3个哨兵节点。这时,如果哨兵集群中有个哨兵挂掉了,那么还剩下两个个哨兵,如果这个哨兵想要成为Leader,这时还是有机会达到2票的,所以还是可以选举成功的,不会导致无法进行主从节点切换。
  当然,你要问,如果3个哨兵节点,挂了2个怎么办?这个时候得人为介入了,或者增加多一点哨兵节点。
  再说一个问题,Redis1主4从,5个哨兵,quorum设置为3,如果2个哨兵故障,当主节点宕机时,哨兵能否判断主节点客观下线?能否自动切换?哨兵集群可以判定主节点客观下线。哨兵集群还剩下3个哨兵,当一个哨兵判断主节点主观下线后,询问另外2个哨兵后,有可能能拿到3张赞同票,这时就达到了quorum的值,因此,哨兵集群可以判定主节点为客观下线。哨兵集群可以完成主从切换。当有个哨兵标记主节点为客观下线后,就会进行选举Leader的过程,因为此时哨兵集群还剩下3个哨兵,那么还是可以拿到半数以上(5213)的票,而且也达到了quorum值,满足了选举Leader的两个条件,所以就能选举成功,因此哨兵集群可以完成主从切换。
  如果quorum设置为2的话,并且有3个哨兵故障。此时哨兵集群还是可以判定主节点为客观下线,但是哨兵不能完成主从切换了,大家可以自己推演下。
  quorum的值建议设置为哨兵个数的二分之一加1,例如3个哨兵就设置2,5个哨兵设置为3,而且哨兵节点的数量应该是奇数。如何通知客户端新主节点的信息?
  经过前面一系列的操作后,哨兵集群终于完成了主从故障迁移,那么新主节点的信息要如何通知给客户端呢?
  这主要通过Redis的发布者订阅者机制来实现的。每个哨兵节点提供发布者订阅者机制,客户端可以从哨兵订阅消息。
  比如,客户端订阅了主从切换的事件,当哨兵把新主节点选择出来后,就会发布新主节点的IP地址和端口信息,这个时候客户端就可以收到这条信息,然后用这里面的新主节点的IP地址和端口进行通信了。哨兵集群是如何组成的?
  前面提到了Redis的发布者订阅者机制,那就不得不提一下哨兵集群的组成方式,因为它也用到了这个技术。
  在我第一次搭建哨兵集群的时候,当时觉得很诧异。因为在配置哨兵的信息时,竟然只需要填下面这几个参数,设置主节点名字、主节点的IP地址和端口号以及quorum值。sentinelmonitormasternameipredisportquorum
  不需要填其他哨兵节点的信息,我就好奇它们是如何感知对方的,又是如何组成哨兵集群的?
  后面才了解到,哨兵节点之间是通过Redis的发布者订阅者机制来相互发现的。
  在主从集群中,主节点上有一个名为sentinel:hello的频道,不同哨兵就是通过它来相互发现,实现互相通信的。
  在下图中,哨兵A把自己的IP地址和端口的信息发布到sentinel:hello频道上,哨兵B和C订阅了该频道。那么此时,哨兵B和C就可以从这个频道直接获取哨兵A的IP地址和端口号。然后,哨兵B、C可以和哨兵A建立网络连接。
  通过这个方式,哨兵B和C也可以建立网络连接,这样一来,哨兵集群就形成了。
  哨兵集群会对从节点的运行状态进行监控,那哨兵集群如何知道从节点的信息?
  主节点知道所有从节点的信息,所以哨兵会向主节点发送INFO命令来获取所有从节点的信息。
  如下图所示,哨兵B给主节点发送INFO命令,主节点接受到这个命令后,就会把从节点列表返回给哨兵。接着,哨兵就可以根据从节点列表中的连接信息,和每个从节点建立连接,并在这个连接上持续地对从节点进行监控。哨兵A和C可以通过相同的方法和从节点建立连接。
  正式通过Redis的发布者订阅者机制,哨兵之间可以相互感知,然后组成集群,同时,哨兵又通过INFO命令,在主节点里获得了所有从节点连接信息,于是就能和从节点建立连接,并进行监控了。
  参考资料:《Redis核心技术与实战》《Redis设计与实现》总结
  Redis在2。8版本以后提供的哨兵(Sentinel)机制,它的作用是实现主从故障自动转移。它会监测主节点是否存活,如果发现主节点挂了,它就会选举一个从节点切换为主节点,并且把新主节点的相关信息通知给从节点和客户端。
  哨兵一般是以集群的方式部署,至少需要3个哨兵节点,哨兵集群主要负责三件事情:监控、选主、通知。
  哨兵节点通过Redis的发布者订阅者机制,哨兵之间可以相互感知,相互连接,然后组成哨兵集群,同时哨兵又通过INFO命令,在主节点里获得了所有从节点连接信息,于是就能和从节点建立连接,并进行监控了。
  哨兵集群会通过投票的方式判定主节点是否客观下线,如果判定主节点为客观下线,那么就会从所有的从节点中选择一个作为新主节点,选择的规则有以下步骤:过滤掉已经离线的从节点;过滤掉历史网络连接状态不好的从节点;将剩下的从节点,进行三轮考察:优先级、复制进度、ID号。在每一轮考察过程中,如果找到了一个胜出的从节点,就将其作为新主节点。
  选择好从节点后,就需要从哨兵集群选择一个leader执行主从切换。选举leader的过程,也是一个投票的过程,任何一个想成为leader的哨兵节点,要满足两个条件:第一,拿到半数以上的赞成票;第二,拿到的票数同时还需要大于等于哨兵配置文件中的quorum值。
  选举完leader哨兵节点后,就执行主从切换。完成主从切换后,通过Redis的发布者订阅者机制通知客户端新主节点的IP地址和端口。原文链接:https:mp。weixin。qq。comsHJHNq3MOSJDC0cPAFzIw
  作者:小林coding
  如果觉得本文对你有帮助,可以转发关注支持一下

太吾绘卷血童不死流BD参考《太吾绘卷》中血童不死身是非常强力的功法,能够保证玩家们的生存能力,想要知道该流派如何搭配的玩家请看下面《太吾绘卷》血童不死流BD参考,希望能够帮助大家。内功洗髓经加大太……芯片价格下降,有的比雪糕刺客还便宜近日,芯片价格雪崩引发热议,部分芯片从去年高位的200元降至现在的20元一个,对比不久前还有大佬打飞的求芯片,仿佛一夜之间,芯片价格就雪崩了。芯片进入降价周期?根据……华中大于涛教授课题组发PRL,在超导磁子学研究领域取得重要进日前,《物理评论快报》(PhysicalReviewLetters)在线刊发了华中科技大学物理学院于涛教授量子磁性与自旋物理课题组题为Efficientgatingofmagn……4大主力受伤!无缘欧国联,法国队连遭打击,恐以最耻辱方式出局近日,德甲豪门拜仁官方宣布,球队的边锋科曼出现了伤情,在一次训练中,科曼的右大腿肌肉纤维撕裂,他将暂时缺席比赛。《图片报》跟进了科曼的伤情,预计科曼将缺阵23周,当9月底的国家……延迟退休或将被取代,新的退休计划受众人拥护,有利于教师目前,中国已经进入老龄化社会,也就是说,老年人的数量在增加,年轻人的数量在减少。数据显示,截至2022年上半年,中国60岁以上老人的数量达到2。67亿。预计到2025年,它将超……UFC选手后台发生肢体冲突,李景亮劝架,衣服弄脏,险酿87人日前,随着UFC279发布会宣布取消,中国格斗名将李景亮不得不推迟自己的亮相。不过,大家在为亮哥感到遗憾的同时,也对为何取消计划之中的新闻发布会疑惑不已。在一片猜测声中,答案终……新加坡最新回国航班机票再度涨到10万块一张疫情当下,除了天价蔬菜包、天价跑腿费之外,机票价格更是一路疯涨,尤其国际航班,简直要掏空你的钱包!8月新加坡最新飞中国航班信息出炉,最贵机票价格接近10万块一张!这趟航班……今天,人民灵境研究院正式宣布成立今天,2022游戏责任论坛在北京举行,这是由人民网主办、金报电子音像出版(北京)有限公司承办的,值得注意的是,在这次会上,人民灵境研究院正式宣布成立。这是研究修仙的吗?不是!……苹果Mac系列收入下降10库克称供应链问题导致【CNMO新闻】近日,据CNMO了解,苹果最新公布的第三季度财报略微超出外界的预期。报告显示,iPhone手机的收入同比略有增长,服务部门收入也增长了12。但在其他方面,该公司……北苏拉威西俯冲带地震海啸风险研究获进展近日,中国科学院南海海洋研究所边缘海与大洋地质重点实验室林间团队在北苏拉威西俯冲带潜在大地震和海啸灾害的研究中取得新进展。相关研究成果发表在《海洋与石油地质》(Marinean……江苏长江及沿海地区纺企停工限产率升高中国棉花网专讯:近期,由于员工感染无法出工情况有所增加,长江、沿海地区中小型纺织及织布企业开机率出现下降。当地某企业负责人表示,因多数员工居家,企业开机率仅60。近年来长……杨伟民高质量发展不是不要速度,只有量的增长才可能有质的提升杨伟民资料图12月25日,在以经济高质量发展与中国特色金融发展之路为主题的中国财富管理50人论坛2022年会上,中央财办原副主任杨伟民表示,推动高质量发展不是不要速度,只……
米果智能助力航天三江食堂智慧升级,提升食堂经营管理是什么让航天三江大厦食堂快速升级为智慧食堂?是什么让食堂用餐高峰期拥挤情况得到全面改善?是什么让员工就餐用餐不再烦恼?秘密就在于米果智能智慧食堂管理系统。……云南白药胶囊是治什么的云南白药胶囊止血效果怎么样云南白药胶囊是我们大家经常能见到的一种药物,而我们大家很多人也都使用过云南白药胶囊,但是很少有人知道此药品主治什么,因此我们便来了解云南白药胶囊是治什么的?云南白药胶囊止血效果……胡明轩在场上拼抢很凶,常常让比赛充满悬念,是中国男篮防守尖兵当一个人自身具备某些条件,在某一方面极具天赋时,只要有合适的机会,遇到欣赏自己的伯乐,便可进入发挥自己特长的平台,而这只是开始,在这个领域之中,依然还需要不断地努力,也要持之以……华晨宇王悦伊恋情曝光,两人用情侣手机壳新鲜狗粮自从华晨宇被拍到与王悦伊携手回家后,他一直保持低调,从未回应过新的关系。然而,从媒体拍摄的照片来看,他们的关系发展似乎非常顺利。上个月,华晨宇录制了一个节目,王悦伊跟着他,画面……吃哪些食物可以高效补充维生素A作者:李晶(主任医师)维生素是维持生命的营养素,以前称维他命就是取这个意思。大多数的维生素,机体不能自动合成或合成量不足,必须经常通过食物获得。人体必需维生素有12种,它……消炎药吃几天为宜消炎药一天吃几次感冒对于我们来说是一种还比较常见的疾病,很多人在感冒的时候大多是通过吃药来进行治疗,但有时在感冒的时候还会伴随着嗓子疼,这是因为嗓子发炎导致的,所以这时就需要配合吃消炎药,那么……感冒灵颗粒可以空腹喝吗感冒灵颗粒可以吃几天感冒灵是我们都熟悉的一种药物,很多人在感冒的时候都喝过这种药,而且有的人会在空腹的时候就喝药,实际上有的药是不可以空腹服用的,因此我们便来了解一下感冒灵颗粒可以空腹喝吗?感冒灵……泰山功勋现身野球场!曾有机会随队夺冠,如今已无球可踢或将退役时间过得很快,8月已经过去了1个多礼拜,也就是说现在距离本赛季最后一个转会窗的关闭只剩下了3周的时间。由于近2年中超联赛变得越来越不景气,不少俱乐部都出现了不同程度的欠薪……头发分叉怎么办?头发油怎么办?一头飘逸的长发让你女人味十足,然而头发天天洗,还是油腻,看着十分不卫生讲究。头发分叉厉害,梳头各种打结短发。万千烦劳丝,究竟该怎么办?头发油的原因头发油,其实是头皮……白醋小苏打洗洁精比例多少正确市面上贩售各式各样的速效清洁液或去污液,长期购买累积下来,也会是一笔不小的开销。精明的家庭主妇们如果想要省钱,其实在家也可以DIY哦。大家可能都听过,用小苏打粉加醋可以去污,却……城野医生胎盘素功效与作用城野医生的护肤品是大家比较熟悉的领域,今天5号网的小编要为你们介绍的是城野医生胎盘素功效与作用。城野医生胎盘素功效与作用这款Dr。Ci:Labo城野医生胎盘素Placen……手机型号后面的ProPlusMaxNote都是什么意思?看完不管东西好不好,名字一定要高大上。手机圈很好的诠释了这一点,不管什么手机,后面的后缀名是一大堆,除了卖手机以及资深手机玩家,还真是不一定能全部搞清楚。不同的品牌,对自家品……
友情链接:易事利快生活快传网聚热点七猫云快好知快百科中准网快好找文好找中准网快软网