码迷,mamicode.com
首页 > 其他好文 > 详细

redis主从复制之全量复制与部分复制

时间:2019-11-27 10:34:44      阅读:93      评论:0      收藏:0      [点我收藏+]

标签:主从复制   block   产生   节点数据   主从   闪断   部分   sla   处理   

一、什么事全量复制与部分复制?

全量复制:一般用于初次复制场景,Redis早期支持的复制功能只有全量复制,它会把主节点全部数据一次性发送给从节点,当数据量较大时,会对主从节点和网络造成很大的开销.

部分复制:用于处理在主从复制中因网络闪断等原因造成的数据丢失场景,当从节点再次连上主节点后,如果条件允许,主节点会补发丢失数据给从节点。因为补发的数据远远小于全量数据,可以有效避免全量复制的过高开销。

部分复制是对老版复制的重大优化,有效避免了不必要的全量复制操作。

二、全量复制的逻辑

redis服务节点启动时,会产生一个run_id标识(服务重启时run_id会发生变化)。slave节点会记住master节点的run_id,在复制主节点的过程中发现master节点的run_id发生,将会进行全量复制。

认识run_id

info server#

三、部分复制的逻辑
部分复制即复制偏移量。
通过对比主从节点的复制偏移量,可以判断主从节点数据是否一致。

redis主从复制之全量复制与部分复制

标签:主从复制   block   产生   节点数据   主从   闪断   部分   sla   处理   

原文地址:https://blog.51cto.com/phpme/2453902

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!