《Redis设计与实现》读书笔记-第三部分:多机数据库的实现-2:Sentinel

目录

 1.启动并初始化sentinel

1.1初始化服务器

1.2使用sentinel专用代码

1.3初始化sentinel状态 

1.4初始化sentinel状态的masters属性

1.5创建连向主服务器的网络连接

 2.获取主服务器信息


Sentinel(哨岗、哨兵)是redis的高可用性解决方案:有一个或多个Sentinel实例(instance)组成的sentinel系统(system)可以监视任意多个主服务器以及这些主服务器属下的所有从服务器,并在被监视的主服务器进入下线状态时,自动将下线的主服务器属下的某个从服务器升级为新的主服务器,然后由新的主服务器代替已下线的主服务器继续处理命令请求。

假设这时,主服务器server1进入下线状态,那么从服务器server2、server3、server4对主服务器的复制操作将被中止,并且sentinel系统会察觉server1已下线: 

 

 1.启动并初始化sentinel

1.1初始化服务器

因为sentinel本质上是一个运行在特殊模式下的redis服务器,所以启动sentinel的第一步,就是初始化一个普通的redis服务器。不过因为sentinel执行的工作和普通的redis执行的工作不同,所以sentinel的初始化过程和普通的redis服务器的初始化过程并不完全相同。

1.2使用sentinel专用代码

启动sentinel的第二步就是将一部分普通的redis服务器代码替换成Sentinel专用代码。 

1.3初始化sentinel状态 

1.4初始化sentinel状态的masters属性

 

1.5创建连向主服务器的网络连接

 2.获取主服务器信息

 sentinel默认会以每十秒一次的频率,通过命令连接向被监视的主服务器发送INFO命令,并通过分析INFO命令的回复来回复来获取主服务器的当前信息。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值