Redis-哨兵模式
admin
2024-02-10 19:02:07
0

目录

哨兵概念

配置与启动哨兵

哨兵工作原理


  • 哨兵概念

  • 首先来看一个业务场景:
  • 如果redis的master宕机了,此时应该怎么办?
  • 那此时可能需要从一堆的slave中重新选举出一个新的master
  • 那这个操作过程是什么样的呢?这里面会有什么问题出现呢?
  • 要实现这些功能,就需要redis的哨兵
  • 那哨兵是什么呢?
  • 哨兵
  • 哨兵(sentinel)是一个分布式系统
  • 用于对主从结构中的每台服务器进行监控,当出现故障时通过投票机制选择新的master并将所有slave连接到新的master
  • 哨兵的作用:
  • 监控:
    • 监控master和slave
    • 不断的检查master和slave是否正常运行
    • master存活检测、master与slave运行情况检测
  • 通知(提醒):
  • 当被监控的服务器出现问题时,向其他(哨兵间,客户端)发送通知
  • 自动故障转移:
  • 断开master与slave连接,选取一个slave作为master,将其它slave连接新的master,并告知客户端新的服务器地址
  • 注意:哨兵也是一台redis服务器,只是不提供数据相关服务,通常哨兵的数量配置为单数
  • 配置与启动哨兵

  • 配置一拖二的主从结构(利用之前的方式启动即可)
  • 配置三个哨兵(配置相同,端口不同),参考sentinel.conf
  • 1:设置哨兵监听的主服务器信息, sentinel_number表示参与投票的哨兵数量
  • sentinel monitor master_name master_host master_port sentinel_number
  • 2:设置判定服务器宕机时长,该设置控制是否进行主从切换
  • sentinel down-after-milliseconds master_name million_seconds
  • 3:设置故障切换的最大超时时长
  • sentinel failover-timeout master_name million_seconds
  • 4:设置主从切换后,同时进行数据同步的slave数量,数值越大,要求网络资源越高,数值越小,同步时间越长
  • sentinel parallel-syncs master_name sync_slave_number
  • 启动哨兵
  • redis-sentinel filename
  • 哨兵工作原理

  • 哨兵在进行主从切换过程中经历三个阶段
    • 监控
    • 通知
    • 故障转移
  • 阶段一:监控
  • 用于同步各个节点的状态信息
    • 获取各个sentinel的状态(是否在线)
    • 获取master的状态
      • master属性
        • runid
        • role:master
      • 各个slave的详细信息
    • 获取所有slave的状态(根据master中的slave信息)
      • slave属性
        • runid
        • role:slave
        • master_host、master_port
        • offset
        • ....
  • 阶段二:通知
  • sentinel在通知阶段要不断的去获取master/slave的信息,然后在各个sentinel之间进行共享
  • 例其中一个sentinel抢先给每个节点发送hello,看有没有那个服务器宕机了,如果一切正常,就给其它sentinel通知正常
  • 阶段三:故障转移
  • 确认master是否真的宕机
    • sentinel1一直向master发送hello,发现没有响应
    • sentinel1获取到flags:SRI_S_DOWN的信息,主观判断master已经挂了
    • 给其它的sentinel发送SENTINEL is-master-down-by-addr ........ ,也就是说,告诉其它sentinel,master已经挂了
    • 其它sentinel不轻易相信sentinel1,于是好奇,给master发送hello,探测一下master是不是真的挂了
    • 由于超过半数的sentinel都说master挂了,那么master就真的挂了
    • 更新SentinelRedisInstance的master信息为flags:SRI_O_DOWN
  • 投票选举一个sentinel去进行主从切换的处置操作
    • 五个哨兵在微信群上各自发送一条消息,每个哨兵既参与竞选又参与投票
    • 投票规则是这样的:在一个时刻里面,谁先收到哪个发送者的信息,谁就投票给哪个发送者
    • 假设在极短的时间内,只有sentinel1和sentinel4的网络状态非常良好,于是比其它sentinel先发出消息了
    • 这时候,sentinel2最先接收到sentinel1的信息,sentinel4慢了一步,所以sentinel2会给sentinel1投票,sentinel1的票数+1
    • 按照这个规则去投票,票数最多的那个sentinel被安排主从切换的处置操作
  • 主从切换的处置操作
    • 备选原则如下列表:
    • 服务器列表中挑选备选master
      • 在线的(保留)
      • 响应慢的(被OUT)
      • 与原master断开时间久的(被OUT)
    • 优先原则
      • 优先级(优先级高的保留)
      • offset(偏移量小的保留)
      • runid(runid小的保留)
    • 发送指令
    • 向新的master发送slaveof no one,告知新的master,恭喜你,你当上领导了
    • 向其它slave发送slaveof 新master的IP和端口,告知各位slave兄弟们,你们去连接新的master吧

相关内容

热门资讯

安卓系统为什么会赢,技术革新与... 你有没有想过,为什么安卓系统在智能手机市场上如此火爆,几乎成了“手机必备”的存在呢?今天,就让我带你...
电脑可以做安卓系统么,电脑上运... 你有没有想过,电脑能不能装上安卓系统呢?这听起来是不是有点像科幻电影里的情节?别急,让我带你一探究竟...
国产安卓系统碎片化软件,软件生... 你有没有发现,现在手机上的安卓系统越来越丰富多样了?没错,这就是我们今天要聊的话题——国产安卓系统的...
安卓系统的蚂蚁花呗,蚂蚁花呗在... 你知道吗?在安卓系统的世界里,有一个超级方便的支付工具,那就是蚂蚁花呗。它就像你的贴心小助手,让你在...
安卓2系统彩蛋在哪找,揭秘隐藏... 你有没有发现,安卓2系统里竟然隐藏着一些神秘的彩蛋?没错,就是那些让你忍不住想要一探究竟的小惊喜。今...
全球最大的安卓系统,全球最大移... 你知道吗?在智能手机的世界里,有一个系统可是当之无愧的“王者”——那就是安卓系统!它就像一位全能的魔...
安卓系统就没有碎片了,迈向无缝... 你知道吗?最近在科技圈里,安卓系统可是掀起了一阵不小的波澜呢!有人说,安卓系统再也没有碎片化了?这可...
安卓系统平板电脑评测,安卓平板... 你有没有想过,在这个信息爆炸的时代,拥有一台性能卓越的安卓系统平板电脑,简直就是移动办公和娱乐的完美...
双系统安卓自动关机,双系统安卓... 你有没有遇到过这样的情况:手机里装了双系统安卓,一边是工作用的,一边是娱乐用的,结果有时候不小心,手...
圣地安列斯安卓9系统,圣地安列... 亲爱的读者,你是否也像我一样,对科技新动态充满好奇?今天,我要和你分享一个超级有趣的话题——圣地安列...
平果有安卓系统的吗,畅享智能生... 你有没有想过,手机的世界里,竟然还有这样一个有趣的现象?那就是——平果手机,竟然也有安卓系统!是不是...
vivoy27安卓系统下载,畅... 你有没有听说最近Vivo Y27这款手机的新鲜事儿?没错,就是它的安卓系统下载!今天,我就要给你来个...
安卓系统最强定位手机版,最强定... 你有没有想过,在茫茫人海中,如何让你的手机定位功能像侦探一样精准无误?今天,就让我带你一探究竟,揭秘...
安卓运行环境选哪个系统,And... 你有没有想过,你的安卓手机到底是在哪个运行环境下才能发挥出最佳性能呢?这可是个技术活儿,选对了系统,...
zui15系统是安卓系统吗,揭... 亲爱的读者,你是否曾好奇过,那些在手机上运行得风生水起的系统,它们究竟是不是安卓的呢?今天,就让我带...
ios系统和安卓系统权限区别,... 你有没有发现,无论是手机还是平板,我们用的最多的就是那些APP了。而这些APP,它们在手机里可是有着...
荣耀手环6安卓版系统,智能生活... 你有没有注意到,最近你的手腕上是不是多了一抹亮丽的色彩?没错,说的就是荣耀手环6安卓版系统!这款智能...
极品奴隶系统下载安卓版,体验独... 你有没有听说过那个超级火的“极品奴隶系统”安卓版?最近,这款游戏在朋友圈里可是炸开了锅,大家都说它好...
安卓手机苹果系统扣费,揭秘扣费... 你有没有遇到过这种情况?手机里突然多了一笔扣费,而且还是那种你完全没意识到的扣费?尤其是当你用的是安...
安卓系统智能电视刷机,焕新体验 亲爱的电视迷们,你是否曾为你的安卓智能电视的性能所困扰?是不是觉得它运行缓慢,功能受限?别担心,今天...