3.2.5 Redis哨兵高可用机制

哨兵(Sentinel)机制核心作用

在这里插入图片描述
在这里插入图片描述

核心运作流程

在这里插入图片描述

七大核心概念

在这里插入图片描述

哨兵启动和配置

在这里插入图片描述
sentinel-26380.conf中的内容

# 配置文件:sentinel.conf,在sentinel运行期间是会被动态修改的
# sentinel如果重启时,根据这个配置来恢复其之前所监控的redis集群的状态
# 绑定IP
bind 0.0.0.0
# 后台运行
daemonize yes
# 默认yes,没指定密码或者指定IP的情况下,外网无法访问
protected-mode no
# 哨兵的端口,客户端通过这个端口来发现redis
port 26381
# 哨兵自己的IP,手动设定也可自动发现,用于与其他哨兵通信
# sentinel announce-ip
# 临时文件夹
dir /tmp
# 日志
logfile "/var/log/redis/sentinel.log"
# sentinel监控的master的名字叫做mymaster,初始地址为 192.168.100.241 6380,2代表两个及以上哨兵认定为死亡,才认为是真的死亡
sentinel monitor redis-1 192.168.0.102 6380 2
# 发送心跳PING来确认master是否存活
# 如果master在“一定时间范围”内不回应PONG 或者是回复了一个错误消息,那么这个sentinel会主观地(单方面地)认为这个master已经不可用了
sentinel down-after-milliseconds redis-1 1000
# 如果在该时间(ms)内未能完成failover操作,则认为该failover失败
sentinel failover-timeout redis-1 3000
# 指定了在执行故障转移时,最多可以有多少个从Redis实例在同步新的主实例,在从Redis实例较多的情况下这个数字越小,同步的时间越长,完成故障转移所需的时间就越长
sentinel parallel-syncs redis-1 1

启动容器

与启动redis容器类似,启动一个别名为sentinel的容器

docker run -it --name sentinel-1 -p 26380:26380 -p 6379:6379 -v /root/sentinel-26380.conf:/usr/local/etc/redis/sentinel.conf -d redis /bin/bash

进入容器

docker exec -it sentinel-1 bash

创建日志目录和文件

mkdir /var/log/redis

touch /var/log/redis/sentinel.log

启动哨兵
redis-sentinel /usr/local/etc/redis/sentinel.conf

查看日志,哨兵成功监听到一主和两从的机器

哨兵如何知道Redis主从信息

在这里插入图片描述

什么是主观下线(sdown)

在这里插入图片描述

哨兵之间如何通信

在这里插入图片描述

什么是客观下线(odown)

在这里插入图片描述

哨兵领导选举机制

在这里插入图片描述

slave选举方案

在这里插入图片描述

最终主从切换的过程

在这里插入图片描述

哨兵服务部署方案

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值