Redis复制(主从复制)

CAP原理

 C - Consistent , 一致性
 A - Availability , 可用性
 P - Partition tolerance , 分区容忍性

Redis的最终一致性

在这里插入图片描述

复制概念

在Redis中,用户可以通过执行SLAVEOF命令或者设置slaveof选项,让一个服务器去复制(replication)另一个服务器。

在这里插入图片描述
快照同步------>完整同步
增量同步----->部分重同步

旧版复制功能实现

Redis的复制功能分为同步命令传播两个操作:

  • 同步操作用于将从服务器的数据库状态更新值主服务器当前所处的数据库状态;
  • 命令传播操作则用于在主服务器的数据库状态被修改,导致主从服务器的数据库状态出现不一致的时,让主从服务器的数据库状态重新回到一致状态。

同步(也叫快照复制)

当客户端向服务器发送SLAVEOF命令,要求服务器复制主从服务器时,从服务器首先需要执行同步操作,也就是,将从服务器的数据库状态更新之主服务器当前所处的数据库状态。
从服务器对主服务器的同步操作需要通过向主服务器发送SYNC命令来完成,以下是SYNC命令的执行步骤:
在这里插入图片描述
在这里插入图片描述

命令传播(同步完成之后的更新保持一致)

为了让主从服务器再次回到一致的状态,主服务器需要对从服务器执行命令传播操作:主服务器会将自己执行的写命令,也就是造成主从服务器不一致的那条命令,发送给从服务器执行,当从服务器执行了相同的谢明令之后,主从服务器将再次回到一致的状态。

旧版复制功能的缺陷

在这里插入图片描述

新版复制功能的实现

为了解决旧版复制功能在处理断线重复制情况时的低效问题,Redis从2.8版本开始,使用PSYNC命令代替SYNC命令来执行复制时的同步操作。
PSYNC命令具有完整重同步(快照)部分重同步(增量)两种模式:

  • 其中完整重同步用于处理初次复制情况:完整重同步的执行步骤和SYNC命令执行步骤基本一致,它们都是通过主服务器创建并发送RDB文件,以及向从服务器发送保存在缓冲区里面的写命令执行同步
  • 部分重同步则用于处理断线后重复复制的情况,当从服务器在断线后重新连接柱服务器时,如果条件允许,主服务器可以将主从服务器连接断开期间执行的写命令发送给从服务器,从服务器只要接受并执行这些写命令,就可以将数据库更新之主服务器当前所处的状态。

PSYNC命令的部分重同步模式解决了旧版复制功能在处理断线后重复度复制时出现的低效情况

在这里插入图片描述

部分重同步的实现(增量同步)

部分重同步功能由以下三个部分构成:

  • 主服务器的复制偏移量(replication offset)和从服务器的复制偏移量
  • 主服务器的复制积压缓冲区
  • 服务器运行的ID

复制偏移量

主服务器每次向从服务器传播N个字节的数据时,就将自己的复制偏移量的值加上N;从服务器每次收到主服务器传播来的N个字节数据时,就将自己的复制偏移量的值加上N;如果主从服务器处于一致状态,那么主从服务器两者偏移量相同

复制积压缓冲区

复制积压缓冲区是由主服务器维护的一个固定长度先进先出队列,默认大小为1MB
当主服务器进行命令传播时,它不仅会将写命令发送给所有从服务器,还会将写命令入队到复制积压缓冲区里面。

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

调整复制积压缓冲区:根据主服务器写命令是否频繁

服务器运行ID

除了复制偏移量和复制积压缓冲区之外,实现部分重同步还需要用到服务器ID

在这里插入图片描述

PSYNC的实现

在这里插入图片描述

复制的实现(详细版本)

通过SLAVEOF命令可以实现复制,下面介绍具体如何实现:

设置主服务器的地址和端口

slave of 127.0.0.1 6379
从服务器首先要做的是将客户端给定的主服务器IP地址127.0.0.1以及端口号637保存

建立套接字

从服务器将根据命令所设置的IP地址和端口,创建连向主服务器的套接字连接

发送PING命令:测试连通性

身份验证

发送端口信息

同步

在这里插入图片描述

命令传播

在这里插入图片描述

心跳检测

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值