范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

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

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

华为掌舵人任正非你真的了解他的英明之处吗?华为掌舵人任正非,随着华为手机的大卖美国打压华为事件,迅速成为国人追捧的企业家。有人评价说,中国不缺商业大家,但是缺像任总这样的民族企业家。我们先来回顾一下任正非的生平,他本是部队腾讯的反击先来说一段旧闻2013年3月15日,著名的315打假晚会当晚,晚会播出过程中,影星何润东突然以315在行动为标签在微博上指责苹果手机,但在内容的结尾竟出现一句大概8点20分发,此举挺正常的,腾讯也毕业优化了2022年往前3年为起点,累计投入超过1366亿元!建立起了服务器操作系统芯片技术SaaS软件服务平台等在内的完整自研体系对,上面说的其实是腾讯,马化腾作为主要创始人之一的腾讯。近python之字符串内置函数1。字符串字母处理str。capitalize()首字母大写str。upper()全部转为大写字母str。lower()全部转为小写字母str。swapcase()大小写相互转换svivoS15Pro图赏除了最擅长的拍照,它还想做的更全面一些5月19日,vivo发布vivoS15和vivoS15ProvivoS15e三款手机。其中vivoS15使用的是时下流行的直面屏搭配圆角矩形的机身,而vivoS15Pro则用的是曲拍银河别想了再聊拍人都费劲的笔记本摄像头2015年以前,笔记本摄像头位于屏幕上方正中间,无可撼动CES2015上,采用三面微边框的XPS13惊艳亮相,为了给微边框和DELLLogo让路,摄像头被移到了屏幕左下角MWC20短短三个月,菜鸟在比利时列日大发神威,带来ampquot指数级增长ampquot2018年12月,菜鸟宣布在比利时的列日机场投建22万平方米的智能物流骨干网欧洲段的数字枢纽。仅仅三个月,这个曾经宁静而悠闲的欧洲十字路口变得热闹异常。无论航空还是铁路运输都达到了疑似PS5开发机曝光图?更多细节被展露随着PS4和XboxOne的老化,下一代游戏机时代就快要来临。在现在的游戏机市场中,索尼几乎占据了主导地位,其生产的产品PS4销量高达9400万部,甩开微软的产品几条街。最近一张疑大陆退至第三!SEMI2018年全球半导体材料市场营收创新高芯科技消息(文罗伊)国际半导体协会(SEMI)公布最新全球半导体材料市场报告(SEMIMaterialsMarketDataSubscription),数据显示2018年全球半导体Elasticsearch实现跨集群复制功能?目前,Elasticsearch6。5。0是Elastic最为稳定的版本,它是基于Lucene7。5。0开发的,可以实现通过ElasticCloud的Service进行部署。Ela百度无人驾驶汽车升级,100辆自动驾驶出租车将要投入市场4月2日,百度创始人董事长兼CEO李彦宏在长沙宣布,百度年底将在长沙投放100辆自动驾驶车辆。时间拉回到两年前,还记得七月的百度AI开发者大会上,刚刚推出无人车时的尴尬吗?百度老总
移动公司发放新利好,10年没换号的老客户,可享受四大特权手机在人们的日常生活中发挥着重要的作用,无论是基础性工作还是聊天娱乐,它都能被利用得很好。如今大众的手机依赖症愈加明显,离开手机几分钟就会魂不守舍,总觉得缺了什么东西,似乎手机不离智能无主灯和传统的无主灯有什么区别?很多人可能还不知道什么叫无主灯,所谓无主灯是指空间照明不再依赖传统的吸顶灯吊灯等作为主灯,而是利用射灯筒灯轨道灯等新光源实现见光不见灯的设计效果。并且无主灯设计由于其光源角度亮度与小屏旗舰不死!除了iPhone,用户还有小屏骁龙898手机可选纵观这两年的手机,能称得上小屏旗舰的产品,恐怕也就只有苹果的iPhone系列了,上一代的iPhone12系列以及这一代的iPhone13系列,苹果都有mini这一型号。无论是芯片性标准续航的汉EV与低配毛豆3,到底该选谁?2021年被誉为碳中和元年,环保理念开始走进万千家庭。消费者在选购家用轿车时也优先将新能源汽车纳入考虑的范围。但说到今年关注度最高的新能源车型,不得不提及的就是比亚迪汉EV与特斯拉iPhone13虽好,但这两款安卓旗舰仍是不错的选择,看看你选对了吗今年苹果的新品iPhone13系列已经正式发布了,高配以上版本均有很大提升,并且起步就是128GB内存,看得出苹果为中国市场做出了妥协,也有很多消费者都表示愿意为这款手机买单,但其OPPO新专利在手机侧面配额外摄像头可捕捉移动物体在最新获批的专利中,OPPO计划在手机的侧面装备一枚额外摄像头,以便于从不同角度拍摄照片和视频。它对于捕捉动作瞬间也很有用,可以追踪移动的物体,而不必将设备移到身边。该专利名为电子苹果iPad9搭载强大的A13仿生芯片10。2英寸屏幕AppleiPad新款机型(第九代),搭载强大的A13仿生芯片,在保持全天候电池续航的同时,进一步提升性能和功能。新款iPad起售价为RMB2,499。新款iPad自即日起在app为什么安装win11后,电脑速度变快了,微软在这三方面进行了改进Windows11看起来确实不一样,你会发觉安装新操作系统后,电脑运行速度变得更快了,这主要是由于微软对系统底层的性能进行了改进,特别是在操作系统如何处理多个应用程序,以及电脑如何5G手机除了上网速度快,还能做什么?5G手机上网速度比4G手机快不到哪去,准确的说5G手机的优势是下载速度快,一部大片2,3秒就能下到手机里,这个点确实4G手机比不了。问题是谁没事干手机下载电影玩?5G的特性天生就是哈尔滨发展这么快,三年内能发展成国际化大都市吗?哈尔滨发展了,这是必然的,为什么这样说呢!第一,城市管理者水平全国第一,去红旗大街与建北小区交口看看就知道了,建设垃圾就在路中央堆积一年多,杂草众生!第二,你来香坊区祥和家园看看就三星Exynos2200正式版主频曝光?三星S22后置主摄GN5?三星Exynos2200旗舰手机处理器芯片,采用三星4纳米制程工艺,还有全新的V9构架。这颗芯片正式版主频相比测试版在主频上果然提升了很多。三星Exynos2200测试的时候,采用