Redis 主从复制的原理

Redis 主从复制

Redis 主从复制,是指在 Redis 集群里面(如图),Master 节点和 Slave 节点数据同步的一种机制。简单来说就是把一台 Redis 服务器的数据,复制到其他 Redis 服务器中。其中负责复制数据的来源称为 master,被动接收数据并同步的节点称为 slave。
在 Redis 里面,提供了全量复制和增量复制两种模式。全量复制一般发生在 Slave 节点初始化阶段,这个时候需要把 master 上所有数据都复制一份。

全量复制

具体的工作原理是:
  1. Slave 向 Master 发送 SYNC 命令,Master 收到命令以后生成数据快照
  2. 把快照数据发送给 Slave 节点,Salve 节点收到数据后丢弃旧的数据,并重新载入新的数据
需要注意,在主从复制过程中,Redis 并没有采用实现强数据一致性,因此会存在一定时间的数据不一致问题。

增量复制

增量复制,就是指 Master 收到数据变更之后,把变更的数据同步给所有 Slave 节点。增量复制的原理是,Master 和 Slave 都会维护一个复制偏移量(offset),用来表示Master 向 Slave 传递的字节数。每次传输数据,Master 和 Slave 维护的 Offset 都会增加对应的字节数量。Redis 只需要根据 Offset 就可以实现增量数据同步了。

总结

Redis 主从复制包括全量复制和增量复制:
  • 全量复制是发生在初始化阶段,从节点会主动向主节点发起一个同步请求,主节点收到请求后会 会生成一份当前数据的快照发送给从节点,从节点收到数据进行加载后完成全量复制。
  • 增量复制是发生在每次 Master 数据发生变化的过程中,会把变化的数据同步给所有的从节点。增量复制是通过维护 Offset 这个复制偏移量来实现的。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值