Redis的高可用之哨兵模式

Redis哨兵主要是解决Redis主从同步时主数据库宕机问题,使其能够自动进行故障恢复,提高Redis系统的高可用性。

1. 哨兵的作用:

监控 :哨兵通过心跳机制监控主库和从库的存活性。
选主 :当主库宕机时,哨兵会选举出一个领导者哨兵来完成主从切换。
通知:哨兵将新主库的地址通知给所有从库和客户端。

2. 监控机制:

a. 哨兵通过配置文件获取主库地址,并定期发送INFO replication命令来获取主从拓扑关系。

b. 哨兵使用pub/sub机制在sentinel:hello频道上发布和订阅消息,以感知其他哨兵的存在。

c. 哨兵每隔1秒向主库、从库和其他哨兵发送PING命令进行探活。
主观下线 :单个哨兵在一定时间内没有收到主库响应时,认为主库主观下线。
客观下线:当半数以上哨兵同意主库主观下线时,认为主库客观下线。

3. 选主过程:

a. 一旦主库被认定为客观下线,哨兵之间会进行选举,选出一个领导者哨兵。

b. 选举过程采用过半投票机制,是基于哨兵之间的通信和共识算法。

4. 故障恢复:

领导者哨兵负责故障恢复,包括选出一个健康的从库提升为新主库,并将其他从库配置为新主库的从库。

5. 从库选择:

选择从库时会过滤掉不健康的节点,然后根据优先级、复制偏移量和runid进行排序,选择最优的从库作为新主库。

相关推荐
霖霖总总28 分钟前
[小技巧19]MySQL 权限管理全指南:用户、角色、授权与安全实践
数据库·mysql·安全
heartbeat..5 小时前
Spring AOP 全面详解(通俗易懂 + 核心知识点 + 完整案例)
java·数据库·spring·aop
麦聪聊数据7 小时前
MySQL并发与锁:从“防止超卖”到排查“死锁”
数据库·sql·mysql
AC赳赳老秦8 小时前
DeepSeek 私有化部署避坑指南:敏感数据本地化处理与合规性检测详解
大数据·开发语言·数据库·人工智能·自动化·php·deepseek
YMatrix 官方技术社区9 小时前
YMatrix 存储引擎解密:MARS3 存储引擎如何超越传统行存、列存实现“时序+分析“场景性能大幅提升?
开发语言·数据库·时序数据库·数据库架构·智慧工厂·存储引擎·ymatrix
辞砚技术录9 小时前
MySQL面试题——索引2nd
数据库·mysql·面试
linweidong10 小时前
C++thread pool(线程池)设计应关注哪些扩展性问题?
java·数据库·c++
欧亚学术11 小时前
突发!刚刚新增17本期刊被剔除!
数据库·论文·sci·期刊·博士·scopus·发表
黑白极客11 小时前
怎么给字符串字段加索引?日志系统 一条更新语句是怎么执行的
java·数据库·sql·mysql·引擎
码农水水11 小时前
中国邮政Java面试:热点Key的探测和本地缓存方案
java·开发语言·windows·缓存·面试·职场和发展·kafka