redis主从复制原理

Redis主从同步有2种,SYNC和PSYNC, PSYNC是优化版的SYNC,2.8版本才有,废话不多说直接看图!

SYNC的原理
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

SYNC有缺点,就是掉线后的同步,需要进行全量同步,没有增量同步功能。
在这里插入图片描述

SYNC缺点

1.生成RDB文件,将耗费主服务器CPU、内存和磁盘I/O资源

2.RDB文件发送给从服务器,耗费主网络资源,对主响应命令请求的时间产生影响。

3.从服务器载入RDB文件,在载入期间,因为阻塞而没办法处理命令请求。

4.当掉线后即便至少了很少数据也需要全量同步。

因为有以上缺陷所以Redis2.8版本后增加了PSYNC同步方式。

PSYNC
在这里插入图片描述

这是执行原理
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

实现方式就是redis利用复制缓冲积压区记录一部分数据,大小是1MB,数据结构是环形队列。有个offset变量,主服务器记录大小,从服务器记录同步到哪个offset。

如果从服务器发送的offset已经不在缓冲命令区里面就会进行全量同步了,

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值