Redis集群主从模式

2023-11-07  本文已影响0人  风雪_夜归人

主从复制

旧版复制

Redis的复制功能分为同步(sync)和命令传播(command propagate)两个操作:
同步操作用于将从服务器的数据库状态更新至主服务器当前所处的数据状态;
命令传播操作则用于在主服务器的数据库状态被修改,导致主从服务器的数据库状态出现不一致时,让主从服务器的数据库重新回到一致状态。

同步:
当客户端向服务器发送slaveof命令,要求从服务器复制主服务器时,从服务器首先需要执行同步操作,将从服务器的数据库状态更新至主服务器当前所处的数据库状态

命令传播
在执行完同步操作后,主从服务器之间数据库状态已经相同,但这个状态并非一成不变,如果主服务器执行了写操作,那么主服务器的数据库状态就会修改,所以为了让主从服务器再次回到一致状态,主服务器需要对从服务器执行命令传播操作;主服务器会将自己执行的写命令,也即是造成主从服务器不一致的那条写命令,发送给从服务器执行,当从服务器执行了相同的写命令后,主从服务器将再次回到一致状态。

旧版复制的缺陷

在redis中,从服务器对主服务器的复制可以分为以下两种情况:
1.初次复制:从服务器以前没有复制过任何主服务器,或者从服务器当前要复制的主服务器和上一次复制的祝福完全不同;
2.断线后重复制:处于命令传播阶段的主从服务器因为网络原因而中断了复制,但从服务器通过自动重连接重新连接上了主服务器,并继续复制主服务器。

SYNC命令是一个非常耗费资源的操作,因为每次执行SYNC命令,主从服务器需要执行以下操作:
1)主服务器需要执行BGSAVE命令来生成RDB文件,这个生成操作会耗费主服务器大量的cpu、内存和磁盘IO资源;
2)主服务器需要将自己生成的RDB文件发送给从服务器,这个发送操作会耗费主从服务大量的网络资源(带宽和流量),并对主服务器响应命令请求的时间产生影响
3)接收到RDB文件的从服务器需要载入主服务器发来的RDB文件,并且在载入期间,从服务器会因为阻塞而没办法处理命令请求。

新版复制

上一篇 下一篇

猜你喜欢

热点阅读