hooyantsing's Blog

34_哨兵模式详解

字数统计: 828阅读时长: 2 min
2020/08/19

34 哨兵模式详解

Redis最新超详细版教程通俗易懂

哨兵模式(自动选举老大)

概述

主从切换技术的方法是:当主服务器宕机后,需要手动把一台服务器切换为主服务器,这就需要人工干预,费时费力,还会造成一段时间内服务不可用。这不是一种推荐的方式,很多时候,我们优先考虑 哨兵模式。Redis从 2.8 开始正式提供 Sentinel(哨兵) 架构来解决这个问题。

哨兵模式是一种特殊的模式,首先Redis提供了哨兵命令,哨兵是一个 独立的进程 ,作为进程它会独立运行。其原理是 哨兵通过发送命令,等待Redis服务器响应,从而监控运行的多个Redis实例

19110c7e95d3a908158e45e18cfa82a5.png

Redis 提供的哨兵:

1d585a94f2dda9e650c72f049ca89359.png

这里哨兵有两个作用:

  • 通过发送命令,让 Redis 服务器返回监控其运行状态,包括主服务器和从服务器。
  • 当哨兵检测到master宕机,会自动将slave切换成master,然后通过发布订阅模式通知其他的从服务器,修改配置文件,让它们切换主机。
    然而一个哨兵进程对Redis服务器进行监控,可能会出现问题。因此,我们可以使用多个哨兵进行监控。各个哨兵之间还会进行监控,这样就形成了多哨兵模式

c75f25fe94954a2c2488e942eae70473.png

假设主服务器宕机,哨兵1先检测到这个结果,系统并不会马上进行 failover 过程,仅仅是哨兵1主观的认为主服务器不可用,这个现象称为 主观下线 。当后面的哨兵也检测到主服务器不可用,并且数量达到一定值时,那么哨兵之间就会进行一次投票,投票的结果由一个哨兵发起,进行 failover(故障转移)操作。切换成功后,就会通过发布订阅模式,让各个哨兵把自己监控的从服务器实际切换主机,这个过程称为 客观下线

测试

目前的状态 一主二从。

以下参数不能错,否则哨兵失效。

  1. 配置哨兵配置文件 kconfig/sentinel.conf

参数:被监控的名称 监视的IP 端口 至少有1个哨兵确认

1
sentinel monitor myredis 127.0.0.1 6379 1
  1. 启动哨兵
    1
    redis-sentinel kconfig/sentinel.conf

启动哨兵进程:

28ba6f50f69dcc780cf3723e75a417b0.png

如果主机发生故障,过一小段时间后,经过哨兵投票,将选举出新的主机。(在哨兵控制台可以看到日志信息)

如果主机从故障中恢复,只能归并到新主机之下作从机。(主人当奴隶,大人时代变了)

哨兵模式

优点:

  1. 哨兵集群,基于主从复制模式,所有的主从配置优点,它都有。

  2. 主从可以切换,故障可以转移,系统可用性更好。

  3. 哨兵模式就是主从模式的升级,手动到自动,更健壮。
    缺点:

  4. Redis不好在线扩容,集群容量一旦达到上限,在线扩容就十分麻烦。

  5. 实现哨兵模式的配置其实是很麻烦的,里面有很多选择。

    哨兵模式的全部配置

b52392a392009fc1174bd35285281c4f.png

b8d00253dd3fcfc2b6935d256aa0cdd5.png

de053d685ce726b28b17ec2d7efdab25.png

3847126adc70873f98ec6e26c078ca4c.png

CATALOG
  1. 1. 34 哨兵模式详解
    1. 1.1. 哨兵模式(自动选举老大)