redis夯实之路-哨兵(Sentinel)机制详解

Sentinel(哨兵)保证了redis的高可用性,一个Sentinel或多个Sentinel组成的系统监视多个主从服务器,当主服务器下线时,自动将一个从服务器升级为主服务器。

sentinel的主要功能

  1. 集群监控:负责监控redis master和slave进程是否正常工作
  2. 消息通知:如果某个redis实例有故障,那么哨兵负责发送消息给管理员
  3. 故障转移:如果master node挂掉了,会自动转移到slave node上
  4. 配置中心:提供可靠的master地址,如果故障转移发生了,通知client客户端新的master地址

Sentinel启动时

  1. 初始化服务器
  2. 使用sentinel专用代码
  3. 初始化sentinel状态
  4. 初始化sentinel状态的master属性(master属性记录了所有被监视的主服务器信息)
  5. 创建连向主服务器的网络连接(一个是命令连接,一个是订阅连接)

获取主服务器的信息:sentinel会以每10s一次的频率通过命令连接来向被监视的主服务器发送info命令,并通过命令的回复来获得主服务器的当前信息,对其实例结构进行更新。会创建从服务器的实例结构并保存到所属主服务器的实例结构的slaves字典中

获取从服务器的信息:sentinel也会创建到从服务器的命令连接和订阅连接,创建命令连接后以每10s一次的频率通过命令连接来向从服务器发送info命令,并通过命令的回复来获得从服务器的信息,对其实例结构进行更新

Sentinel为主服务器创建的实例结构中的sentinels字典保存了除Sentinel本身之外,所有同样监视这个主服务器的其他Sentinel的资料。

Sentinel通过频道信息发现新的sentinel时,会建立命令连接

检查主观下线状态

sentinel默认以每秒一次向所有与它建立了命令连接的实例(主从服务器,其他sentinel)发送ping命令,通过回复判断是否在线

检查客观下线状态

sentinel将一个主服务器判断为主观下线后,向其他监视该服务器的sentinel询问,如果认为该服务器下线的sentinel数量足够多,将判断为客观下线,对主服务器执行故障转移操作

一个主服务器被判断为客观下线后,将从监视这个主服务器的sentinel中选择一个领头sentinel执行故障转移操作

故障转移

将下线主服务器的从服务器中选出一个作为新主服务器,其他从服务器改为复制新的主服务器,已下线的主服务器也改为复制新的主服务器。

相关推荐
等....8 小时前
Minio使用
数据库
win x9 小时前
Redis 使用~如何在Java中连接使用redis
java·数据库·redis
迷枫7129 小时前
DM8 数据库安装实战:从零搭建达梦数据库环境(附全套工具链接)
数据库
XDHCOM10 小时前
PostgreSQL 25001: active_sql_transaction 报错原因分析,故障修复步骤详解,远程处理解决方案
数据库·sql·postgresql
卤炖阑尾炎10 小时前
PostgreSQL 日常运维全指南:从基础操作到备份恢复
运维·数据库·postgresql
daad77712 小时前
wifi_note
运维·服务器·数据库
xixingzhe212 小时前
Mysql统计空间增量
数据库·mysql
程序员萌萌13 小时前
Redis的缓存机制和淘汰策略详解
数据库·redis·缓存机制·淘汰策略
不剪发的Tony老师13 小时前
SQLite 3.53.0版本发布,重要更新
数据库·sqlite
Bczheng113 小时前
九.Berkeley DB数据库 序列化和钱包管理(1)
数据库