从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/