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已经不在缓冲命令区里面就会进行全量同步了,