美文网首页
Redis集群主从模式

Redis集群主从模式

作者: 风雪_夜归人 | 来源:发表于2023-11-07 20:17 被阅读0次

主从复制

  • 在redis中,用户可以通过执行slaveof命令或者设置slaveof选项,让一个服务器去复制(repllcate)另一个服务器,我们称呼被复制的服务器为主服务器(master),而对主服务进行复制的服务器则被称为从服务器(slave)。配置原则:配从不配主

  • 解除主从关系命令:slaveof no one

旧版复制

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

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

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

旧版复制的缺陷

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

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

新版复制

  • Redis从2.8版本开始。使用PSYNC命令替代SYNC命令来执行复制时的同步操作 。

  • PSYNC命令具有完整重同步(full resynchronization)和部分同步(partial resynchronization)两种模式:

  • 完整重同步用于处理初次复制情况:完整重同步的执行步骤和SYNC命令的执行步骤基本一样,它们都是通过让主服务器创建并发送RDB文件,以及向从服务器发送保存在缓冲区里面的写命令来进行同步;

  • 部分重同步则用于处理断线后重复制情况:当从服务器在断线后重新连接主服务器时,如果条件允许,主服务器可以将主从服务器连接断开期间执行的写命令发送给从服务器,从服务器只要接收并执行这些命令,就可以将数据库更新至主服务器当前所处的状态

  • 部分重同步的实现,由以下三个部分构成:
    1.主服务器的复制偏移量(replication offset)和从服务器的复制偏移量;
    2.主服务器的复制积压缓冲区(replicaiton backlog)
    3.服务器端运行ID(run ID)

相关文章

  • Redis集群部署

    Redis集群部署 Redis集群有多种部署模式,包括主从模式、哨兵模式、集群模式 主从模式   主从模式可以是一...

  • Docker环境搭建redis集群(主从模式)

    Docker环境搭建redis集群(主从模式) 序 本文将介绍如何在docker中部署redis集群(主从模式)。...

  • 11.Redis集群入门

    本主题,介绍了Redis的集群配置与编程入门,其实Redis的集群还包含主从集群模式,哨兵集群模式(Redis 5...

  • redis的三种集群方式

    redis的三种集群方式 redis有三种集群方式:主从复制,哨兵模式和集群。 1.主从复制 主从复制原理: 从服...

  • redis 主从模式、哨兵(sentinel) 配置、clust

    前言:先了解一下redis主从模式、哨兵模式、cluster(集群)模式 1、主从模式:是三种集群方式里最简单的。...

  • Redis集群

    Redis有三种集群模式,分别是: 主从复制 Sentinel模式 Cluster模式 主从复制 主从模式,是指将...

  • 第五章----Redis三种集群详解

    Redis集群的三种模式 主从复制(master/slave) 哨兵模式(sentinel) 集群模式(clust...

  • 14. Redis 主从复制

    9. Redis高可用集群 9.1 主从复制架构 主从模式(master/slave), 可以实现Redis数据的...

  • Loki 日志系统分布式部署实践三 redis

    说明 这里支持 redis 主从、哨兵、集群三种模式,我这里选择主从即可,集群模式测试异常,没能解决 安装 安装 ...

  • redis主从同步原理(浅谈)

    1.前言在redis中为了保证redis的高可用,一般会搭建一种集群模式就是主从模式。主从模式可以保证redis的...

网友评论

      本文标题:Redis集群主从模式

      本文链接:https://www.haomeiwen.com/subject/gevoidtx.html