Redis主从复制断点续传的工作原理概述

从redis 2.8开始,如果在主从复制过程中遭遇连接断开,则重新连接之后可以从中断处继续进行复制,而不必重新同步。


断点续传的工作原理具体如下:

主服务器端为复制流维护一个内存缓冲区(in-memory backlog)。主从服务器都维护一个复制偏移量(replication offset)

和master run id。

当连接断开时,从服务器会重新连接上主服务器,然后请求继续复制,假如主从服务器的两个master run id相同,并且指定的

偏移量在内存缓冲区中还有效, 则复制就会从上次中断的点开始继续。如果其中一个条件不满足,就会进行完全重新同步

(在2.8版本之前就是直接进行完全重新同步)。


因为主运行id不保存在磁盘中,因此如果从服务器重启了的话就只能进行完全同步了。


对于部分重新同步这个新特性,redis 2.8版本内部使用PSYNC命令,旧版本的实现中使用的是SYNC命令。

redis2.8版本可以检测出它所连接的服务器是否支持PSYNC命令,若不支持则使用SYNC命令。


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/15498/viewspace-2375172/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/15498/viewspace-2375172/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值