【Redis】三种集群模式(主从、哨兵、集群) + 如何保证数据一致

本文详细介绍了Redis的三种集群模式:主从、哨兵和Cluster。主从模式通过PSYNC命令实现数据同步,哨兵模式监控主从服务器,确保高可用性,自动执行故障转移。Cluster模式提供了更高级的分布式解决方案,解决数据一致性问题。
摘要由CSDN通过智能技术生成

前言

Redis有三种集群模式:

  • 第一个就是主从模式(经典用来存储数据)
  • 第二种哨兵模式(监控主从服务器,保证高可用)
  • 第三种是Cluster集群模式

这三种模式都如何保证节点间的数据一致性呢?

一、主从集群模式

1、第一次连线时

  1. 当向一个节点输入slaveof 命令时,他会变成某个节点的从服务器,之后从服务器向主服务器发送PSYNC ? -1命令(SYNC是老版的同步命令,只支持全量同步,现在已经舍弃),开始同步请求。
  2. 收到SYNC命令的主服务器执行BGSAVE命令, 在后台生成一个RDB文件, 并使用一个缓冲区(注意,这个缓冲区不是复制积压缓冲区!!!)记录从现在开始执行的所有写命令。
  3. 当主服务器的BGSAVE命令执行完毕时, 主服务器会将RDB文件发送给从服务器, 从服务器接收并载入这个RDB文件, 将自己的数据库状态更新至主服务器刚开始执行BGSAVE时的数据库状态。
  4. 主服务器将记录在缓冲区里面的所有写命令发送给从服务器, 从服务器执行这些写命令, 将自己的数据库状态更新至主服务器数据库当前所处的状态。

2、从服务器重连时

需要用到三个东西:

  1. 偏移量
  2. 复制积压缓冲区
  3. 主服务器运行ID(补充一下,其实主从服务器都有自己的ID,只不过在这里我们只说主服务器ID

另外,我们所说的复制积压缓冲的概念仅仅是;增量同步时才有的概念。

当从服务器重新连上主服务器时, 从服务器会通过PSYNC+主机ID(40个随机的16进制字符)+偏移量offset 命令将自己的复制偏移量offset发送给主服务器,:

  1. 首先,主服务器会对比从服务器发过来的ID是否与自己的ID一致,如果不一致那么说明从服务器断线之前复制的主服务器并不是当前连接的这个主服务器, 主服务器将对从服务器执行完整重同步操作。
  2. 如果一致,主服务器会根据这个复制偏移量来决定对从服务器执行何种同步操作。
  3. 如果offset偏移量之后的数据(也即是偏移量offset+1开始的数据)仍然存在于复制积压缓冲区里面, 那么主服务器将对从服务器执行部分重同步操作。主服务器向从服务器发送+C0NTINUE回复, 表示数据同步将以部分重同步模式来进行。接着主服务器会将复制积压缓冲区偏移量之后的所有数据都发送给从服务器。从服务器只要接收这些缺失数据, 就可以回到与主服务器一致的状态。
  4. 如果,偏移量之后的数据已经不存在于复制积压缓冲区(可能是由于时间过长,缓冲区毕竟就1M的大小), 那么主服务器将对从服务器执行完整重同步操作。

流程图

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值