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主从复制建立成功。之后主库的每一个写命令都会通过命令传播机制传给从库执行,从而保持主从数据的一致性。