【redis】主从复制机制

1、概述

1.1简介

  • Redis的RDB主从复制(Master-Slave Replication)是一种用于数据冗余和可伸缩性的机制,它允许数据从一个主节点(Master)同步到一个或多个从节点(Slave)。

2.1复制原理

  • 异步复制:Redis的主从复制是异步的,只保证最终一致性,而不是强一致性。这意味着主库上的写命令操作后传到从库再重现一遍,从库执行完后主从是完全同步的,但在这个过程中可能会有短暂的延迟。
  • 命令传播:在主从复制建立成功后,每当主服务器接收到一个写命令时,为了保证主从数据的一致性,主服务器会将这个写命令传播到从服务器上执行。

2、优缺点

2.1优点

  • 数据冗余:主从复制提供数据副本,可以用于灾难恢复。
  • 读写分离:通过主从复制,主服务器可以处理写操作,从服务器可以处理读操作,从而实现读写分离,提高系统的并发性能。
  • 高可用集群:通过主从复制,可以实现高可用性的集群,当主服务器出现故障时,从服务器可以自动接管,从而提高系统的可用性。

2.2缺点

  • 数据延迟:在高负载下,从节点与主节点之间的数据同步可能会有延迟,不能保证实时的强一致性。
  • 成本:维护更多的服务器会增加硬件和运维成本。
  • 写扩展限制:所有的写操作仍然需要通过主节点进行,因此主从复制不会提高写操作的性能。

3、工作流程

  • 从库向主库发送SYNC命令:从库向主库发送同步请求,请求获取主库的数据快照。
  • 主库执行BGSAVE命令:主库接收到SYNC命令后,会执行BGSAVE命令,这个命令会创建一个RDB文件,该文件是主库当前状态的快照。在创建RDB文件的过程中,主库上执行过的写命令都会被保存到缓冲区中。
  • 主库发送RDB文件给从库:当主库执行完BGSAVE命令后,会将生成的RDB文件发送给从库。从库接收并加载这个文件,将自己的数据库状态更新至主服务器执行BGSAVE命令时的数据库状态。
  • 主库发送缓冲区写命令给从库:主库将缓冲区中积累的写命令发送给从库执行,以确保从库与主库的数据状态保持一致。
  • 主从复制建立成功:至此,Redis主从复制建立成功。之后主库的每一个写命令都会通过命令传播机制传给从库执行,从而保持主从数据的一致性。

  • 8
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值