首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >redis实战第二篇 哨兵 redis sentinel

redis实战第二篇 哨兵 redis sentinel

作者头像
我是李超人
发布2020-08-21 10:41:25
5690
发布2020-08-21 10:41:25
举报

原文摘录自《redis开发与运维》

redis sentinel解决主从复制高可用问题 非高可用状态下故障处理 一个主节点、两个从节点 1)主节点发生故障,客户端连接主节点失败,两个从节点和主节点连接终端复制失败 2)选择一个从节点更新为主节点 3)更新应用方的配置信息,更新主节点信息,重新启动 4)待原来的主节点恢复后,将其加入从节点同步新的主节点

从以上流程可以看到,在非高可用的状态下,redis主从备份发生故障时需要较多的人工干预,处理问题效率较低,为此redis专门提供了redis sentinel工具用来自动完成故障发现和故障转移并通知应用方,从而实现高可用。 备注:redis sentinel建议使用redis2.8版本以上

redis sentinel是一个分布式架构,包含若干个sentinel节点和redis数据节点。sentinel节点本身就是redis节点,但是它不存储数据,只支持部分命令。每个sentinel节点会监控其余的节点,当它发现节点不可达时会做下线处理,如果被标识的是主节点,它还会和其它sentinel节点协商,当大多数节点认为主节点不可达时,他们会选举出一个sentinel节点作为领导者负责故障转移的工作,同时会将这个变化通知给应用方。整个过程是自动的,不需要人工干预,所以它有效的解决了redis主从高可用。

redis sentinel拓扑结构

在这里插入图片描述
在这里插入图片描述

redis sentinel故障转移流程图 1)主节点出现故障,此时两个从节点与主节点失去连接,主从复制失败。

在这里插入图片描述
在这里插入图片描述

2)每个Sentinel节点通过定期监控发现主节点出现了故障。

在这里插入图片描述
在这里插入图片描述

3)多个Sentinel节点对主节点的故障达成一致,选举出sentinel-3节点作为领导者负责故障转移。

在这里插入图片描述
在这里插入图片描述

4)Sentinel领导者节点执行了故障转移

在这里插入图片描述
在这里插入图片描述

5)故障转移后整个Redis Sentinel的拓扑结构如图所示

在这里插入图片描述
在这里插入图片描述

从以上流程可以看出redis sentinel具有以下功能: 监控:Sentinel节点会定期检测Redis数据节点、其余Sentinel节点是否可达。 通知:Sentinel节点会将故障转移的结果通知给应用 主节点故障转移:实现从节点晋升为主节点并维护后续正确的主从关系。 配置提供者:在Redis Sentinel结构中,客户端在初始化的时候连接的是Sentinel节点集合,从中获取主节点信息。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-01-28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 Redis
腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档