本篇文章给大家带来了关于Redis的相关知识,其中主要介绍了哨兵模式的相关问题,包括了哨兵概念、哨兵作用、启用哨兵、哨兵原理等等,希望对大家有帮助。
推荐学习:Redis教程
在一主多从结构中,如果master宕机了,就需要从多个slave中选出一个作为新的master,要想完成这样的功能,就需要使用Redis的哨兵机制
哨兵 (sentinel) 是一个分布式系统,用于对主从结构中的每台服务器进行监控,当出现故障时通过投票机制选择新的master并将所有slave连接到新的master,如下图所示:
通知(提醒):当被监控的服务器出现问题时,向其他哨兵、Redis服务器发送通知
故障转移:断开宕机的master与slave的连接,选取一个slave作为master,将其他slave连接新的master,并告知客户端新的服务器地址
注意:哨兵也是一台redis服务器,仅提供监控服务,不提供数据管理服务;通常哨兵的数量配置为单数(方便投票)
修改哨兵的配置文件 sentinel.conf
,配置文件位于Redis目录下,如下图所示:
部分配置的含义如下图所示:
启动哨兵
redis-sentinel filename #filename指的是配置文件名 #每个哨兵都要配置自己的配置文件
配置并启动哨兵之后,主服务器宕机之后,会自动的执行投票、主从切换等过程
哨兵在进行主从切换过程中经历三个阶段:
用于同步各个节点的状态信息,这些节点包括master、slave、哨兵,也就是整个系统所有服务器的信息。
主要完成的功能:
获取各个sentinel的状态(是否在线):新添加的哨兵要与系统中已经存在的哨兵进行信息的交互
获取master的状态(通过info指令)
获取的内容如下
1. master属性 runid role:master 2. 各个slave在master中保存的基本信息
获取所有slave的状态(根据master中slave的信息向所有的slave发送info指令)
获取的内容如下
slave属性 runid role:slave master_host、master_port offset
具体的内部工作原理如下所述:
哨兵在通知阶段要不断的去获取master与slave的信息,然后将获得的信息在各个哨兵之间进行共享。
具体的流程如下:
哨兵通过建立的cmd连接,向master、slave发送 hello
指令,得到他们的信息,然后在关系网中共享:
断开宕机的master与slave的连接,选取一个slave作为master,将其他slave连接新的master,并告知客户端新的服务器地址。
具体的流程如下所述:
哨兵1始终得不到master的回应,主观判断master宕机,标记 sdown
(仅有一个哨兵认为master宕机)
哨兵1在关系网中传递消息,向其他哨兵发送图中左上角的消息
其他哨兵得到消息之后,全部向master发送消息,确定master是否宕机,他们也会将自己得到的结果发送给关系网中的其他哨兵,确定master宕机后,将标记改为 odown
(所有哨兵探测之后,超过一半的哨兵认为master宕机)
当认定master宕机之后,此时需要选举新的master,由哪个哨兵完成这件事要通过哨兵之间的选举决定,具体过程如下所述:
当完成哨兵之间的选举之后,接下来就要由选举胜出的哨兵去slave中挑选一个,将其变成新的master,具体的流程如下所述:
选出新的master之后,哨兵发送指令给服务器:
向新的master发送 slaveof no one
指令
向其他slave发送 slaveof 新masterIP端口
指令
同时还要告诉其他的哨兵新master是谁
监控阶段:同步信息
通知阶段:保持联通
故障转移阶段:
推荐学习:Redis视频教程
以上是一起来分析Redis哨兵模式的详细内容。更多信息请关注PHP中文网其他相关文章!