图解:Redis主从同步与同步流程

目录

一、Redis的主从同步

二、主从同步数据的流程

1.全量同步

图解

2.增量同步

图解

三、完整口述


一、Redis的主从同步

单节点Redis的并发能力是有上限的,要进一步提高Redis的并发能力,就需要搭建主从集群,实现读写分离。

一般都是一主多从,主节点负责写数据,从节点负责读数据。


二、主从同步数据的流程

1.全量同步

1. 从节点请求主节点同步数据(replication id offset

2. 主节点判断是否是第一次请求,是第一次就与从节点同步版本信息(replication id和              offset

3. 主节点执行bgsave,生成rdb文件后,发送给从节点去执行

4. rdb生成执行期间,主节点会以命令的方式记录到缓冲区(一个日志文件)

5. 把生成之后的命令日志文件发送给从节点进行同步

图解

其中:

Replication Id:简称replid,是数据集的标记,id一致则说明是同一数据集。每一个master都有唯一的replidslave则会继承master节点的replid 

offset:偏移量,随着记录在repl_baklog中的数据增多而逐渐增大。slave完成同步时也会记录当前同步的offset。如果slaveoffset小于masteroffset,说明slave数据落后于master,需要更新

2.增量同步

1. 从节点请求主节点同步数据,主节点判断不是第一次请求,就获取从节点的offset

2. 主节点从命令日志中获取offset值之后的数据,发送给从节点进行数据同步

图解

主从增量同步(slave重启或后期数据变化)


三、完整口述

Q:能说一下,主从同步数据的流程吗?

主从同步分为了两个阶段,一个是全量同步,一个是增量同步

  1. 全量同步是指从节点第一次与主节点建立连接的时候使用全量同步,流程是这样的:
    1. 第一:从节点请求主节点同步数据,其中从节点会携带自己的replication id和offset偏移量。
    2. 第二:主节点判断是否是第一次请求,主要判断的依据就是,主节点与从节点是否是同一个replication id,如果不是,就说明是第一次同步,那主节点就会把自己的replication id和offset发送给从节点,让从节点与主节点的信息保持一致。
    3. 第三:在同时主节点会执行BGSAVE,生成RDB文件后,发送给从节点去执行,从节点先把自己的数据清空,然后执行主节点发送过来的RDB文件,这样就保持了一致。
    4. 当然,如果在RDB生成执行期间,依然有请求到了主节点,而主节点会以命令的方式记录到缓冲区,缓冲区是一个日志文件,最后把这个日志文件发送给从节点,这样就能保证主节点与从节点完全一致了,后期再同步数据的时候,都是依赖于这个日志文件,这个就是全量同步。
  2. 增量同步指的是,当从节点服务重启之后,数据就不一致了,所以这个时候,从节点会请求主节点同步数据,主节点还是判断不是第一次请求,不是第一次就获取从节点的offset值,然后主节点从命令日志中获取offset值之后的数据,发送给从节点进行数据同步。

 参考:有关RDBBGSAVERedis的数据持久化

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值