美文网首页
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复制、哨兵、集群

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

  • 【5分钟背八股】redis集群方案有哪些?

    常见集群分类 主从复制集群 分片集群 redis有那些: 主从复制集群,手动切换 带有哨兵的HA的主从复制集群 客...

  • Redis第15章 复制

    Redis集群部署的三种常见方式,复制、哨兵、集群。 复制主写从读,减缓单主的访问压力。 哨兵主从切换,主服务宕机...

  • Redis的高可用

    Redis主从复制 什么是主从复制 Redis有三种集群方案,主从复制,哨兵,cluster集群,主从复制是指将一...

  • redis的三种集群方式

    redis的三种集群方式 redis有三种集群方式:主从复制,哨兵模式和集群。 1.主从复制 主从复制原理: 从服...

  • 第五章----Redis三种集群详解

    Redis集群的三种模式 主从复制(master/slave) 哨兵模式(sentinel) 集群模式(clust...

  • redis 复制 哨兵 集群

    这部分内容菜鸡没实际接触过,简单做个笔记吧。。 复制 SLAVEOF命令或者配置slaveof选项可以replic...

  • redis集群优缺点

    [toc] 集群方案 主从复制 哨兵模 Redis-Cluster ShardedJedisPool 中间件 1....

  • redis包含三种集群策略

    redis包含三种集群策略1,主从复制,2,哨兵3,集群 主从复制 在主从复制中,数据库分为俩类,主数据库(mas...

  • Redis 分布式主从架构

    Redis 集群设计的演变Redis 从最早的集群设计,演变到现在,历经了三种集群状态:(1)主从复制;(2)哨兵...

网友评论

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

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