美文网首页
8.Redis复制、哨兵、集群

8.Redis复制、哨兵、集群

作者: xMustang | 来源:发表于2020-02-24 22:56 被阅读0次

    Redis复制、哨兵、集群

    Redis实现高可用相关的技术,它们包括:持久化、复制、哨兵和集群,其主要作用和解决的问题是:

    1. 持久化:主要作用是数据备份,即将数据存储在硬盘,保证数据不会因进程退出而丢失。
    2. 复制:复制是高可用Redis的基础,哨兵和集群都是在复制基础上实现高可用的。复制主要实现了数据的多机备份,以及对于读操作的负载均衡和简单的故障恢复。缺陷:故障恢复无法自动化;写操作无法负载均衡;存储能力受到单机的限制。
    3. 哨兵:在复制的基础上,哨兵实现了自动化的故障恢复。缺陷:写操作无法负载均衡;存储能力受到单机的限制。
    4. 集群:通过集群,Redis解决了写操作无法负载均衡,以及存储能力受到单机限制的问题,实现了较为完善的高可用方案。

    1 主从复制

    1.1 拓扑结构

    主从拓扑1 主从拓扑2

    1.2 复制模式

    • 全量复制
    • 部分复制:复制积压缓冲区

    1.3 问题点

    • 同步故障
      • 复制数据延迟(不一致):不可避免,可优化网络环境;延迟过大时,通知应用不再通过该从节点读取数据。
      • 读取过期数据(Slave 不能主动删除数据):Redis 3.2中,从节点在读取数据时,增加了对数据是否过期的判断:如果该数据已过期,则不返回给客户端。
      • 从节点故障:需要及时修改应用程序读写Redis数据的连接,手动或自动。
      • 主节点故障:选择一个从节点升为主节点。
    • 避免全量复制
      • 选择小主节点(分片)、低峰期间操作。
      • 如果节点运行 id 不匹配(如主节点重启、运行 id 发送变化),此时要执行全量复制,应该配合哨兵和集群解决。
      • 主从复制积压缓冲区不足产生的问题(网络中断,部分复制无法满足),可增大复制缓冲区( rel_backlog_size )。
    • 复制风暴:当一个主机下面挂了很多个从机时,master 挂了,这时 master 重启后,因为 runid 发生了变化,所有的 slave 都要做一次全量复制,这将引起单节点和单机器的复制风暴,开销会非常大。应该把主节点尽量分散在多台机器上,避免在单台机器上部署过多的主节点。当主节点所在的机器故障后提供故障转移机制,避免机器恢复后进行密集的全量复制。

    2. 哨兵

    2.1 拓扑图

    哨兵拓扑图

    2.2 节点下线

    1. 主观下线
      • 即 Sentinel(哨兵) 节点对 Redis 节点失败的偏见,超出超时时间认为 Master 已经宕机。
      • Sentinel 集群的每一个 Sentinel 节点会定时对 Redis 集群的所有节点发心跳包检测节点是否正常。如果一个节点在 down-after-milliseconds 时间内没有回复 Sentinel 节点的心跳包,则该 Redis 节点被该 Sentinel 节点主观下线。
    2. 客观下线
      • 所有 Sentinel 节点对 Redis 节点失败要达成共识,即超过 quorum 个统一。
      • 当节点被一个 Sentinel 节点记为主观下线时,并不意味着该节点肯定故障了,还需要 Sentinel 集群的其他 Sentinel 节点共同判断为主观下线才行。
      • 该 Sentinel 节点会询问其它 Sentinel 节点,如果 Sentinel 集群中超过 quorum 数量的 Sentinel 节点认为该 Redis 节点主观下线,则该 Redis 客观下线。

    2.3 Leader选举

    选举出一个 Sentinel(哨兵) 作为 Leader:集群中至少有三个 Sentinel 节点,但只有其中一个节点可完成故障转移。

    选举流程:

    1. 每个主观下线的 Sentinel 节点向其他 Sentinel 节点发送命令,要求设置它为领导者。
    2. 收到命令的 Sentinel 节点如果没有同意通过其他 Sentinel 节点发送的命令,则同意该请求,否则拒绝。
    3. 如果该 Sentinel 节点发现自己的票数已经超过 Sentinel 集合半数且超过 quorum,则它成为领导者。
    4. 如果此过程有多个 Sentinel 节点成为领导者,则等待一段时间再重新进行选举。

    2.4 故障转移

    • 转移流程
      1. Sentinel 选出一个合适的 Slave 作为新的 Master(slaveof no one 命令)。
      2. 向其余 Slave 发出通知,让它们成为新 Master 的 Slave( parallel-syncs 参数)。
      3. 等待旧 Master 复活,并使之称为新 Master 的 Slave。
      4. 向客户端通知 Master 变化。
    • 从 Slave 中选择新 Master 节点的规则
      1. 选择 slave-priority 最高的节点。
      2. 选择复制偏移量最大的节点(同步数据最多)。
      3. 选择 runId 最小的节点。

    Sentinel 集群故障转移完成,所有 Sentinel 又会恢复平等。Leader 仅仅是故障转移操作出现的角色。

    3. 分布式集群

    3.1 拓扑图

    分布式集群拓扑图

    3.2 Gossip通讯

    Gossip通讯

    3.3 寻址分片

    3.3.1 hash取模

    • hash(key)%机器数量
    • 问题:当新增或删减节点时,节点数量发生变化,系统中所有的数据都需要重新计算映射关系,引发大规模数据迁移。

    3.3.2 一致性哈希分区

    一致性哈希分区

    3.3.3 带虚拟节点的一致性哈希分区

    CRC16(key)%16384

    带虚拟节点的一致性哈希分区

    相关文章

      网友评论

          本文标题:8.Redis复制、哨兵、集群

          本文链接:https://www.haomeiwen.com/subject/yppjqhtx.html