Redis哨兵模式

Redis哨兵模式

哨兵模式简介

redis的sentinel(哨兵)是用于监控redis集群中master状态的工具,已经被集成在redis2.4+的版本中,是redis官方推荐的高可用性(HA)解决方案。

哨兵模式会检测master的状态,如果master异常,则会进行master和slave切换,将其中一个slave作为master,将之前的master作为slave,master和slave切换成功后,sentinel.conf的监控目标会随之调换。


sentinel的工作模式
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。

哨兵模式部署配置

192.168.226.128 redis-slave1
192.168.226.129 redis-slave2
192.168.226.130 redis-slave3

#三台机器做如下操作,操作都相同
[xiaobai@redis-slave1 redis] vim redis.conf
bind 0.0.0.0
[xiaobai@redis-slave1 redis] vim sentinel.conf
sentinel monitor mymaster 192.168.226.128 6379 2 #当集群中有2个sentinel认为master死了时,才能真正认为该master已经不可用了。 (slave上面写的是master的ip,master写自己ip)
sentinel down-after-milliseconds mymaster 3000   #单位毫秒
sentinel failover-timeout mymaster 10000   #若sentinel在该配置值内未能完成failover(故障转移)操作(即故障时master/slave自动切换),则认为本次failover失败。
protected-mode no  #关闭加密模式--新添加到sentinel配置文件中

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


#三台机器配置完后启动
[xiaobai@redis-slave1 redis] ./src/redis-sentinel sentinel.conf &   #生产坏境要将哨兵模式放在后台启动

在这里插入图片描述

[xiaobai@redis-slave2 redis] ps -ef|grep redis
root       8208   7922  0 14:28 pts/1    00:00:01 ./src/redis-sentinel *:26379 [sentinel]
root       8213      1  0 14:31 ?        00:00:00 ./src/redis-server 0.0.0.0:6379
root       8241   7922  0 14:39 pts/1    00:00:00 grep --color=auto redis
[xiaobai@redis-slave2 redis] kill -9 8213
8208:X 22 Jun 2020 14:41:02.843 # +sdown slave 192.168.226.128:6379 192.168.226.128 6379 @ mymaster 192.168.226.130 6379

在这里插入图片描述

#在此期间slave1机器并不受任何影响
#再次启动slave2机器,master会从slave3变回slave2吗?
[xiaobai@redis-slave2 redis] ./src/redis-server ./redis.conf &
8208:X 22 Jun 2020 14:45:37.424 * +convert-to-slave slave 192.168.226.129:6379 192.168.226.129 6379 @ mymaster 192.168.226.130 6379
#master还在slave3机器上,slave2变成了slave了

文章总览分类目录 @小白

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值