| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 大数据 -> Redis 高可用之哨兵机制 -> 正文阅读 |
|
[大数据]Redis 高可用之哨兵机制 |
主库挂了,如何不间断服务?在前面的文章中,我们分析了 Redis 主从模式。在这个模式下,如果从库发生故障,客户端可以继续向主库或其他从库发送请求,进行相关的操作。但是如果主库发生故障了,那直接就影响到从库的同步,因为从库没有相应的主库可以进行数据复制操作了。 如果说,客户端发送的都是读操作请求,那还可以由从库继续提供服务,这在纯读的业务场景下还能被接受。
这就要提到 哨兵机制了。 在 Redis 主从集群中,哨兵机制是实现主从库自动切换的关键机制,它有效地解决了主从复制模式下故障转移的这三个问题。 哨兵机制哨兵(Sentinel)是 Redis 高可用性的解决方案,它其实就是一个运行在特殊模式下的 Redis 进程,主从库实例运行的同时,它也在运行。
获取主服务器信息Sentinel 通过发送 当 Sentinel 发现从库之后,Sentinel 将对 slave0、slave1和 slave2分别创建命令连接和订阅连接。 创建完命令连接之后,Sentinel 会向从库发送 INFO 命令 获得以下信息:
根据这些信息,?Sentinel 会对从库的实例结构进行更新。 了解了 Sentinel 如何获取主从库的信息之后,下面我们分析下哨兵机制的基本流程。 哨兵机制的基本流程哨兵主要负责的就是三个任务:监控、选主(选择主库)和通知。
我们先看监控。 监控默认情况下,哨兵会以每秒一次的频率向所有主从库发送 Sentinel 配置文件中的 如果一个实例在 细心地同学注意到了,这里说的是主观下线。哨兵对主库的下线判断有 主观下线 和 客观下线 两种。 主观下线和客观下线主观下线:哨兵进程会使用 PING 命令检测它自己和主、从库的网络连接情况,用来判断实例的状态。 如果检测的是从库,那么,哨兵简单地把它标记为「主观下线」?就行了,因为从库的下线影响一般不太大, 但是,如果检测的是主库,那么,哨兵还不能简单地把它标记为「主观下线」?,开启主从切换。因为很有可能存在这么一个情况:那就是哨兵误判了,其实主库并没有故障。 而且,一旦启动了主从切换,后续的选主和通知操作都会带来额外的计算和通信开销。为了避免这些不必要的开销,我们要特别注意误判的情况。 误判误判就是主库实际并没有下线,但是哨兵误以为它下线了。 误判一般会发生在集群网络压力较大、网络拥塞、或者是主库本身压力较大的情况下。 一旦哨兵判断主库下线了,就会开始选择新主库,并让从库和新主库进行数据同步,这个过程本身就会有开销。 而真实的情况是,主库本身根本就不需要进行切换的,所以这个过程的开销是没有价值的。 正因为这样,我们需要判断是否有误判,以及减少误判。 如何减少误判?在日常生活中,当我们要对一些重要的事情做判断的时候,经常会和家人或朋友一起商量一下,然后再做决定。 哨兵机制也是类似的,我们通常会采用多实例组成的集群模式进行部署,也被称为哨兵集群。 引入多个哨兵实例一起来判断,就可以避免单个哨兵因为自身网络状况不好,而误判主库下线的情况。 当 Sentinel 将一个主库判断为主观下线之后,为了确认是否误判,它会向同样监视这一主库的其他 Sentinel 进行询问。只有大多数的哨兵实例,都判断主库已经「主观下线」了,主库才会被判定为「客观下线」,这个叫法也是表明主库下线成为一个客观事实了。 这个判断条件在于 Sentinel 配置中设置的
那么只要有两个 Sentinel 认为主库已经进入下线状态,那么该主库就被判断为「客观下线」。 一般来说,当有 N 个哨兵实例时,最好要有 这样一来,就可以减少误判的概率,也能避免误判带来的无谓的主从库切换。 借助于多个哨兵实例的共同判断机制,我们就可以更准确地判断出主库是否处于下线状态。如果主库的确下线了,哨兵就要开始下一个决策过程了,即从许多从库中,选出一个从库来做新主库。 然后是执行哨兵的第二个任务,选主。 如何选定新主库?主库挂了以后,Sentinel? 就需要从已下线的主库属下的所有从库里,挑选出一个状态良好、数据完整的从库,把它作为新的主库。 这一步完成后,现在的集群里就有了新主库。 一般来说,我们把 Sentinel? 选择新主库的过程称为「筛选 + 打分」。 简单来说,我们在多个从库中,先按照一定的筛选条件,把不符合条件的从库过滤掉。 我们先来看看筛选条件。 筛选条件Sentinel? 会把已下线主库属下的所有从库保存到一个列表中。然后按照以下规则,进行筛选: 1)、一般情况下,我们肯定要保证所选的从库仍然在线运行,所以首先就需要删除列表中处于下线或者断线状态的从库。 不过,在选主时从库正常在线,这只能表示从库的现状良好,并不代表它就是最适合做主库的。 设想一下,如果在选主时,一个从库正常运行,我们把它选为新主库开始使用了。可是,很快它的网络出了故障,此时,我们就得重新选主了。这显然不是我们期望的结果。 所以,在选主时,除了要检查从库的当前在线状态,还要判断它之前的网络连接状态。 2)、删除列表中所有最近 5 秒没有回复过 3)、如果从库总是和主库断连,而且断连次数超出了一定的阈值,我们就有理由相信,这个从库的网络状况并不是太好,就可以把这个从库筛掉了。 具体怎么判断呢? 使用配置项 其中, 如果在 好了,这样我们就过滤掉了不适合做主库的从库,完成了筛选工作。 打分接下来就要给剩余的从库打分了。我们可以分别按照三个规则依次进行三轮打分,这三个规则分别是从库优先级、从库复制进度以及从库 ID 号。 只要在某一轮中,有从库得分最高,那么它就是主库了,选主过程到此结束。如果没有出现得分最高的从库,那么就继续进行下一轮。 第一轮:优先级最高的从库得分高。 我们可以通过
比如,你有两个从库,它们的内存大小不一样,你可以手动给内存大的实例设置一个高优先级。 第二轮:复制偏移量最大的从库得分高。 这个规则的依据是,对具有相同最高优先级所有从库进行排序,选出其中偏移量最大也就是和旧主库数据同步最接近的那个从库作为主库。 如何判断从库和旧主库间的同步进度呢? 前面文章我们提到过,主从库同步时有个命令传播的过程。 在这个过程中,主库会用 此时,我们想要找的从库,它的 就像下图所示,旧主库的
第三轮:运行 ID 最小的从库得分高。 每个实例都会有一个 ID,这个 ID 就类似于这里的从库的编号。目前,Redis 在选主库时,有一个默认的规定: 到这里,新主库就被选出来了,「?选主」这个过程就完成了。 我们再回顾下这个流程:
通知当新的主库出现之后,下一步,哨兵会执行最后一个任务:通知。即让已下线的所有从库去复制新的主库。 通过让从库执行 同时,哨兵会把新主库的连接信息通知给客户端,让它们把请求操作发到新主库上。并且会把已下线的主库设置为新主库的从库。 好了,关于哨兵机制工作的基本流程我们就分析到这里了。如果你还想看更多优质原创文章,欢迎关注我的公众号「ShawnBlog」。 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/17 4:05:32- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |