目录
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命令的回复来回复来获取主服务器的当前信息。