0
点赞
收藏
分享

微信扫一扫

memcache&redis构建缓存服务器(9)redis-sentinel

芥子书屋 2022-06-17 阅读 53

简介

Redis-Sentinel是Redis官方推荐的高可用性(HA)解决方案。实际上这意味着你可以使用Sentinel模式创建一个可以不用人为干预而应对各种故障的Redis部署。


作用

1):Master状态检测  

2):如果Master异常,则会进行Master-Slave切换,将其中一个Slave作为Master,将之前的Master作为Slave  

3):Master-Slave切换后,master_redis.conf、slave_redis.conf和sentinel.conf的内容都会发生改变,即master_redis.conf中会多一行slaveof的配置,sentinel.conf的监控目标会随之调换 


工作方式

1):每个Sentinel以每秒钟一次的频率向它所知的Master,Slave以及其他 Sentinel 实例发送一个 PING 命令  

2):如果一个实例(instance)距离最后一次有效回复 PING 命令的时间超过 down-after-milliseconds 选项所指定的值, 则这个实例会被 Sentinel 标记为主观下线。  

3):如果一个Master被标记为主观下线,则正在监视这个Master的所有 Sentinel 要以每秒一次的频率确认Master的确进入了主观下线状态。  

4):当有足够数量的 Sentinel(大于等于配置文件指定的值)在指定的时间范围内确认Master的确进入了主观下线状态, 则Master会被标记为客观下线 


主观下线和客观下线 

主观下线:Subjectively Down,简称 SDOWN,指的是当前 Sentinel 实例对某个redis服务器做出的下线判断。  

客观下线:Objectively Down, 简称 ODOWN,指的是多个 Sentinel 实例在对Master Server做出 SDOWN  判断,并且通过 SENTINEL is-master-down-by-addr 命令互相交流之后,得出的Master  Server下线判断,然后开启failover.


环境

在上一个实验的基础上。

步骤

1.每台机器上修改redis主配置文件设置:bind 0.0.0.0

2.每台机器上修改sentinel配置文件:添加如下配置

vim /redis-4.0.9/sentinel.conf
sentinel monitor mymaster 192.168.19.100 6379 2
当集群中有2个sentinel认为master死了时,才能真正认为该master已经不可用了。

sentinel down-after-milliseconds mymaster 3000 单位毫秒
如果在down-after-millisecondes毫秒内,没有收到有效的回复,则会判定该节点为主观下线。

sentinel failover-timeout mymaster 10000
若sentinel在该配置值内未能完成failover(故障转移)操作(即故障时master/slave自动切换),则认为本次failover失败。

protected-mode no

3.每台机器启动服务

cd  /redis-4.0.9
./src/redis-sentinel sentinel.conf

4.关闭主服务器,观察从服务器改变状态

master1 
systemctl stop redis
观察三台服务器返回信息。会显示新主人信息

master1
68478:X 16 Jun 21:06:21.352 # +sdown sentinel facf1e964731f6eb448c99ce5759de2a7f40cf94 192.168.19.103 26379 @ mymaster 192.168.19.100 6379

Slave1
8297:X 16 Jun 21:07:02.670 # +sdown slave 192.168.19.100:6379 192.168.19.100 6379 @ mymaster 192.168.19.102 6379

127.0.0.1:6379> info replication
# Replication
role:master
connected_slaves:1
slave0:ip=192.168.19.103,port=6379,state=online,offset=77885,lag=1


Slave2
62335:X 16 Jun 21:07:03.590 # +sdown slave 192.168.19.100:6379 192.168.19.100 6379 @ mymaster 192.168.19.102 6379

127.0.0.1:6379> info replication
# Replication
role:slave
master_host:192.168.19.102


举报

相关推荐

0 条评论