17.Redis之主从复制

news2025/1/6 9:42:27

1.主从复制是怎么回事? 

分布式系统, 涉及到一个非常关键的问题: 单点问题

单点问题:如果某个服务器程序, 只有一个节点(只搞一个物理服务器, 来部署这个服务器程序)

1.可用性问题,如果这个机器挂了,意味着服务就中断了~

2.性能/支持的并发量也是比较有限的~

引入分布式系统,主要也就是为了解决上述的单点问题子
在分布式系统中,往往希望有多个服务器来部署 redis 服务,从而构成一个 redis 集群~~,此时就可以让这个集群给整个分布式系统中其他的服务,提供更稳定/更高效的数据存储功能~~

在分布式系统中,希望使用多个服务器来部署 redis,存在以下几种 redis 的部署方式~~
1.主从模式
2.主从+哨兵模式
3.集群模式

1.1 主从模式 

  • 在若干个 redis 节点中, 有的是"主"节点,有的是"从"节点
  • 假设有三个物理服务器(称为是三个节点)
  • 分别部署了一个 redis-server 进程~~
  • 此时就可以把其中的一个节点,作为"主节点”
  • 另外两个节点作为"从节点”
  • 从节点,得听主节点的~~
  • (从节点上的数据要跟随主节点变化; 从节点的数据要和主节点保持一致)
  • 本来,在主节点上保存一堆数据,引入从节点之后,就是要把主节点上面的数据,复制出来,放到从节点中
  • 后续,主节点这边对于数据有任何修改,都会把这样的修改给同步到从节点上(从节点,就是主节点的副本)
  • 如果我改了从节点的数据,是否是把从节点的数据往主节点上同步呢??
  • Redis 主从模式中, 从节点上的数据,不允许修改!!! 只能读取数据!!

2 主从复制解决的问题

  • 更准确的说,主从模式,主要是针对“读操作”
    进行 并发量 & 可用性 的提高~~
    而写操作的话,无论是可用性还是并发,都是非常依赖主节点.主节点又不能搞多个~~
    实际业务场景中,读操作往往就是比写操作更频繁~~

 3.如何启动多个redis-server

  • 配置 redis 主从结构,首先需要启动多个 redis 服务器~~
  • 正常来说, 每个 redis 服务器程序,应该在一个单独的主机上(才是 分布式 )
  • 但是当前,同学们每个人手里,只有一个云服务器~~(可以在一个云服务器主机上,运行多个 redis-server 进程的~~)【此处需要保证多个 redis-server 的端囗是要不同的】
  • 本来 redis-server默认的端口是 6379
    此时就不能让新启动的 redis-server再继续使用 6379 了.
  • 如何去指定 redis-server 的端口呢?
  • 1.可以在启动程序的时候, 通过命令行来指定端口号. --port 选项
  • 2.也可以直接在配置文件中, 来设定端口~~(此处准备搞一个主节点,两个从节点.主节点的配置不用变~~只需要修改从节点的配置即可~~)
  • 复制原有的文件到新的文件夹
  • 修改从配置文件
  • 1.改端口号
  • 2.daemonize:yes(按照后台的方式进行运行)

4 配置主从复制 

【question】 

这两个进程相互独立

要想配置成 主从结构,就需要使用 slaveof

1.在配置文件中加入 slaveof {masterHost}{masterPort} 随 Reds 启动生效,(修改了配置文件,一直持久生效的)
2.在 redis-server 启动命令时加入-slaveof(masterHost}{masterPort)生效
3.直接使用 redls 命令:slaveof {masterHost}{masterport} 生效

  • 此处以 6379 为主节点.6380 和 6381 为从节点·
  • redis 服务器的配置文件改完了之后,就需要重新启动才能生效!!
  • 这种停止 redis-server 的方式,是和 咱们之前通过 直接运行 redis-server 命令的方式搭配的~~
  • 而如果是使用 service redis-server start 这种方式启动的(此时如果使用 kil -9 的方式停止,kil 掉之后,这个 redis-server 进程能自动启动~~),就必须使用 service redis-server stop 来进行停止~~
  • 上述原因:(往往会有另外一个进程来专门监控指定的服务器进程的运行状态~)
  • 服务器就是要稳定性和高可用~
  • 但是服务器上的某些程序,可能也难以避免出现挂了的情况
    如果服务器进程挂了,要是能自动重启进程(把进程再启动起来),对于整体的服务不会产生严重影响~~
  • 重新运行(启动两个从节点)
  • 多了一些tcp连接

5.查看主从结构信息

  • 从节点还可以再挂从节点

6.断开主从结构和修改主从结构

  • slaveof no one(直接在 redis 客户端中的命令)
  • 直接使用 这个命令 断开现有的主从复制关系~~
  • 从节点断开主从关系,它就不再从属于其他节点了,里面已经有的数据,是不会抛弃的!!
  • 但是,后续主节点如果针对数据做出修改,从节点就无法再自动同步数据了.
  • 此时 6380 看起来向是个主节点
    实际上不是,仍然是从节点
    只是作为 6381 同步数据的来源,自身仍然是不能修改数据的~- 
  • 刚才通过 slaveof 是修改了主从结构~~
  • 此处的修改是临时性的.如果重新启动了 redis 服务器,仍然会按照最初在配置文件中设置的内容来建立主从关系~~

7.主从复制的安全,只读,传输延迟 

7.1 安全性

对于数据⽐较重要的节点,主节点会通过设置 requirepass 参数进⾏密码验证,这时所有的客⼾
端访问必须使⽤ auth 命令实⾏校验。从节点与主节点的复制连接是通过⼀个特殊标识的客⼾端来完成,因此需要配置从节点的masterauth 参数与主节点密码保持⼀致,这样从节点才可以正确地连接到主节点并发起复制流程。

7.2 只读

默认情况下,从节点使⽤ slave-read-only=yes 配置为只读模式。由于复制只能从主节点到从节
点,对于从节点的任何修改主节点都⽆法感知,修改从节点会造成主从数据不⼀致。所以建议线上不要修改从节点的只读模式
  • "主从复制"是从主,到从~~
  • 不能从 从节点 到 主节点 ~~
  • 如果从节点允许修改,后续对于从节点的修改,主节点是感知不到的.数据就不一致了~~

7.3 传输延迟

主从节点⼀般部署在不同机器上,复制时的⽹络延迟就成为需要考虑的问题,Redis 为我们提供
了 repl-disable-tcp-nodelay 参数⽤于控制是否关闭 TCP_NODELAY,默认为 no,即开启 tcp
nodelay 功能,说明如下:
当关闭时,主节点产⽣的命令数据⽆论⼤⼩都会及时地发送给从节点,这样主从之间延迟会变⼩, 但增加了⽹络带宽的消耗。适⽤于主从之间的⽹络环境良好的场景,如同机房部署。
当开启时,主节点会合并较⼩的 TCP 数据包从⽽节省带宽。默认发送时间间隔取决于 Linux 的内
核,⼀般默认为 40 毫秒。这种配置节省了带宽但增⼤主从之间的延迟。适⽤于主从⽹络环境复杂
的场景,如跨机房部署。
  •  主节点和从节点之间通过网络来传输(TCP)
  • TCP 内部支持了 nagle 算法~~(默认开启的)
  • 开启了,就会增加 tcp 的传输延迟节省了网络带宽
  • 关闭了,就会减少 tcp 的传输延迟~ 增加了网络带宽
  • 【目的和 tcp 的捎带应答是一样的针对小的 tcp 数据报,进行合并. 减少了包的个数~~】
  • repl-disable-tcp-nodelay这个选项可以用于在主从同步通信过程中,关闭 tcp 的 naqle 算法~~从节点更快速的和主节点进行同步~~

8.拓扑结构 

若干个节点之间,按照啥样的方式来进行组织连接~~

  • 如果写数据请求太多~~此时也是会给主节点造成一些压力~~可以通过关闭主节点的 AOF, 只在从节点上开启 AOF.
  • 但是,这种设定方式,有一个严重的缺陷~~ 主节点一旦挂了,不能让他自动重启..(如果自动重启此时没有 AOF 文件,就会丢失数据,进一步的主从同步,会把,从节点的数据也给删了)
  • 改进办法,当主节点挂了之后, 就需要让主节点从从节点这里获取到 AOF 的文件.再启动~~
  • 实际开发中, 读请求, 远远超过 写请求
  • 主节点上的数据发生改变, 就会把改变的 数据同时 同步给所有的从节点~随着从节点个数的增加,同步一条数据,就需要传输多次~~
  • 改进
  • 主节点就不需要那么高的网卡带宽了~~
    一旦数据进行修改了,同步的延时是比刚才更长的~~

9.主从复制的基本流程 

10.replicationid的作用

  • redis 提供了 psync 命令,完成数据同步的过程。
  • psync 不需要咱们手动执行
  • redis 服务器会在建立好主从同步关系之后,自动执行 psync
  • 从节点负责执行 psync.从节点从主节点这边拉取数据~~
  • replication 复制~
  • 是主节点生成的。主节点启动的时候就会生成~~
  • 从节点晋升成主节点的时候,也会生成~(即使是同一个主节点,每次重启,生成的 replication id 都是不同的)
  • 从节点和主节点建立了复制关系,就会从主节点这边获取到 replication id 
  • 【当前,此处讨论的都是 一个主节点 多个从节点
    后面谈到 集群 的时候,多个主节点,多个从节点了】
  • info replication 获取到当前 replication id 的值~~
  • 一般情况下 replid2 这个是用不上的~~
  • 有一个主节点 A(生成 replid),还有一个从节点 B(获取到 A 的replid)
  • 如果 A 和 B 通信过程中出现了一些网络抖动~~
  • B 可能就会认为 A 挂了~~
  • B 就会自己成为主节点~~(给自己生成一个 replid)
  • 此时,B 也会记得, 之前 旧的 replid,就是通过 replid2
  • 后续网络稳定了,B 还可以根据 replid2 重新回到 A 的怀抱~~
  • 需要手动干预~~
    哨兵机制, 可以自动完成这个过程

11.offset的作用 

  • 主节点和从节点上都会维护 偏移量 (整数)
  • 主节点的偏移量,主节点上会收到很多的修改操作的命令~~
  • 每个命令都要占据几个字节~~
  • 主节点会把这些修改命令,每个命令的字节数进行累加~
  • 从节点的偏移量,就描述了,现在从节点这里数据同步到哪里了~~
  • 从节点(slave)每秒钟上报自身的复制偏移量给主节点
  • replication id(数据来源) 和 offset(获取进度) 共同描述了一个"数据集合
  • 如果发现两个机器,replication id 一样,offset 也一样,就可以认为这两个 redis 机器上存储的数据就是完全一样的!!

12.全量复制和部分复制 

  • psync 这里可以从主节点获取全量数据,也可以获取一部分数据
  • 主要就是看 offset 这里的进度~~
  • offset 写作 -1,就是获取全量数据
  • offset 写具体的正整数,则是从当前偏移量位置来进行获取~~
  • 获取所有数据,是最稳妥的,但是会比较低效
  • 如果从节点之前已经从主节点这里复制过一部分数据了就只需要把新的之前没复制过的数据搞过来即可~~
  • 不是从节点索要那部分,主节点就一定给哪部分~~
  • 主节点会自行判定,看当前是否方便给部分数据~~不方便就只能给全量了~~
  • 啥时候进行全量复制:
    1.首次和主节点进行数据同步
    2.主节点不方便进行部分复制的时候
  • 啥时候进行部分复制:
    从节点之前已经从主节点上复制过数据了.因为网络抖动或者从节点重启了从节点需要重新从主节点这边同步数据,此时看看能不能只同步一小部分(大部分数据都是一致的)

12.1 全量复制的流程 

从节点主动进行触发

12.2 全量复制的无硬盘模式 

  • 主节点,进行全量复制的时候,也支持"无硬盘模式"(diskless)
  • 主节点,生成的 rdb 的二进制数据,不是直接保存到文件中了~~而是直接进行网络传输了~~(省下了一系列读硬盘和写硬盘的操作)
  • 从节点,之前,也是先把收到的 rdb 数据,写入到硬盘中,然后再加载~~ 现在也可以省略这个过程,直接把收到的数据进行加载了~~
  • 即使引入了无硬盘模式,仍然整个操作是比较重量,比较耗时的网络传输(大规模数据(全量复制))是没法省的~~相比于网络传输来说,读写硬盘是小头~

12.3 关于runid和replid 

  • 1个 redis 服务器上, replication id 和 run id 是都存在的!!!
  • 两个不同的 id,看起来非常像~~

12.4 全量复制的流程 

  • 从节点要从主节点这里进行全量复制.全量复制,开销是很大的.
  • 有些时候,从节点本身已经持有了主节点的绝大部分数据,这个时候,就不太需要进行全量复制了
  • 比如,出现网络抖动~~ 主节点这边最近修改的数据可能就无法及时同步过来了~~更严重的,从节点已经感知不到主节点了~~(进一步的从节点可能会升级成主节点)
  • 网络抖动,一般都是"暂时的",过一会就恢复了~~此时就可以让从节点和主节点重新建立联系~~
  • 当从节点和主节点重新建立连接之后,就需要进行数据的同步~~
  • psync 带有具体的 replid 和 offset 值.主节点就要根据 psync 的参数进行判定~~当前这次是按照全量复制合适还是部分复制合适~~

12.5 实时复制的流程 

  • 全量复制: 从节点刚连上主节点之后,进行的数据初始化工作.
  • 部分复制: 全量复制的特殊情况,优化手段,目的和全量复制一样
  • 实时复制: 从节点,已经和主节点,同步好了数据了~~(从节点这一时刻已经和主节点数据一致了但是之后,主节点这边会源源不断的收到新的修改数据的请求.
  • 主节点上的数据就会随之改变,也需要能够同步给从节点
  • 从节点和主节点之间会建立 TCP 的长连接~~
  • 然后主节点把自己收到的修改数据的请求,通过上述 连接,发给从节点从节点再根据这些修改请求,修改内存中的数据~【这个过程也是需要时间的~正常来说,这个延时是比较短的.但是如果是多级从节点的 树形结构 ~~如果这里从节点的级别很多~~(有很多层),,延时也就会上升】
  • 在进行实时复制的时候,需要保证连接处于可用状态~~
  • 心跳包 机制~
  • 主节点: 默认, 每隔 10s 给从节点发送一个 ping 命令.从节点收到就返回 pong
  • 从节点: 默认, 每隔 1s 就给主节点发起一个特定的请求,就会上报当前从节点复制数据的进度(offset)

13.主从复制小结

主从复制解决的问题:
单点问题.
1. 单个 redis 节点, 可⽤性不⾼.
2. 单个 redis 节点, 性能有限.
主从复制的特点:
1. Redis 通过复制功能实现主节点的多个副本。
2. 主节点⽤来写, 从节点⽤来读. 这样做可以降低主节点的访问压⼒.
3. 复制⽀持多种拓扑结构,可以在适当的场景选择合适的拓扑结构。
4. 复制分为全量复制, 部分复制和实时复制。
5. 主从节点之间通过⼼跳机制保证主从节点通信正常和数据⼀致性。
主从复制配置的过程:
1. 主节点配置不需要改动.
2. 从节点在配置⽂件中加⼊ slaveof 主节点 ip 主节点端⼝ 的形式即可.
主从复制的缺点:
1. 从机多了, 复制数据的延时⾮常明显.
2. 主机挂了, 从机不会升级成主机. 只能通过⼈⼯⼲预的⽅式恢复.

14.问题 

14.1 从节点何时晋升成主节点

  • 主从复制,最大的问题还是在主节点上主节点挂了,从节点就迷茫了~~
  • 虽然能够提供读操作,但是从节点不能自动的升级成主节点~~
  • 不能替换原有主节点对应的角色~~
  • 此时,就需要程序猿/运维手工的恢复主节点~~(非常繁琐的)
  • Redis 哨兵~~ 自动的对挂了的主节点进行替换~~
  • 从节点和主节点之间断开连接,有两种情况:
  • 1.从节点主动和主节点断开连接.
  • slaveof no one
  • 这个时候,从节点,就能够晋升成主节点~~
  • 意味着我们程序猿要主动修改 redis 的组成结构~~
  • 2.主节点挂了~~
  • 这个时候,从节点,不会晋升成主节点的~
  • 必须通过人工干预的方式,恢复主节点~~
  • 这个是脱离咱们掌控的~~ 高可用下的一个典型问题~-

14.2 关于redis主节点无法重启的问题

  • 解决方案:
  • 把三个 redis 服务器的生成的文件,也给区分开~~更靠谱的是,直接把三个 redis 服务器的 工作目录 区分开~~(修改 配置文件 中的 dir 选项)
  • 1.停止之前的 redis 服务器~~
  • 2.删除之前工作目录下 已经生成的 aof 文件~~或者也可以通过 chown 命令修改 aof 文件所属的用户~~
  • 3.给从节点创建出新的目录~用来作为从节点的工作目录~并且修改从节点的配置文件,设定成新的目录为工作目录
  • 4.启动 redis 服务器~~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1718288.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java集合-List(Collection子接口)及其子类(ArrayList、Vector、LinkedList)

List接口是 Collection接口的子接口。 1、List集合类中数据有序, 即添加顺序和取出顺序有序,而且可以重复。 2、List集合类中每个元素都有其对应的顺序索引,即支持索引。例,list.get(2);取第三个元素。 3、实现类有很多…

【linux-imx6ull-设备树点灯】

目录 1. 设备树简介1.1 编译-引用1.2 设备树文件结构1.3 设备树节点介绍1.3.1 特殊节点chosen 1.4 节点内容追加 2. 设备树常用OF操作函数2.1 节点寻找类2.2 属性提取类2.3 其它常用类 4. 设备树下LED实验4.1 实验简介4.2 添加LED设备节点4.3 获取设备节点并提取属性4.3.1 获取…

ChatTTS,语气韵律媲美真人的开源TTS模型,文字转语音界的新魁首,对标微软Azure-tts

前两天 2noise 团队开源了ChatTTS项目,并且释出了相关的音色模型权重,效果确实非常惊艳,让人一听难忘,即使摆在微软的商业级项目Azure-tts面前,也是毫不逊色的。 ChatTTS是专门为对话场景设计的文本转语音模型&#x…

iphone内存满了开不了机怎么办?白苹果解决办法分享!

虽然苹果手机在使用时比较顺畅,但是手机用久了,照片、视频等资料累积过多,也难免会导致内存不足,出现无法开机卡在开机界面白苹果的情况。 内存不足导致iPhone白苹果的问题很常见,可以说是苹果最常见的故障之一。接下来…

探索多模态MR图像的脑肿瘤分割任务结构| 文献速递-深度学习肿瘤自动分割

Title 题目 Exploring Task Structure for Brain Tumor Segmentation From Multi Modality MR Images 探索多模态MR图像的脑肿瘤分割任务结构 01 文献速递介绍 脑肿瘤分割旨在从多模态磁共振(MR)序列中自动分割肿瘤区域,这些序列由先进的…

【Java面试】七、SpringMvc的执行流程、SpringBoot自动装配原理

文章目录 1、SpringMVC的执行流程1.1 视图阶段1.2 前后端分离阶段 2、SpringBoot自动配置原理3、框架常用的注解3.1 Spring的注解3.2 SpringMvc的注解3.3 SpringBoot的注解 4、面试 1、SpringMVC的执行流程 1.1 视图阶段 旧项目中,未前后端分离时,用到…

JVM 指针压缩

运用java内存对齐填充,对java内存进行8字节划分,java对象指针映射到每个划分区域上,使得4个字节(32位)表示2^32个地址,从而使4个字节指针映射32G内存空间。 1.为什么进行指针压缩: jvm从32位变…

【YUV格式数据】【ffplay】播放或者查看YUV格式图片或文件数据

背景 最近在调试hisi解码功能,需要把h264格式解码成yuv数据,调试的时候需要最后查看下出来的yuv格式数据是否正常,需要用到一些工具软件进行查看。然后就做个总结。 解决方案 方案1:使用ffplay命令播放YUV文件 使用ffplay命令…

vue2 bug 小白求助!!!(未解决,大概是浏览器缓存的问题或者是路由的问题)

我的vue2项目出现了一个超级恶心的bug 具体流程: 页面a点击a标签->到页面b->页面b用户退出刷新页面->点击浏览器的返回按钮返回上一页 返回页面后页面没有刷新导致用户名还显示这 项目中没有用keep-alive缓存 也在设置了key 尝试了window.removeEventLi…

【Linux】线程ID

大致草稿—————————— 思维导图 学习目标 一、线程ID的理解 1.1 引出对tid的理解 我们先来创建一个线程复习一下线程的函数: pthread_t tid; // 创建一个线程 pthread_create(&tid, nullptr, threadrun, (void*)"thread-1"); // 打印出…

惯性动作捕捉与数字人实时交互/运营套装,对高校元宇宙实训室有何作用?

惯性动作捕捉与数字人实时交互/运营套装,可以打破时空限制,通过动捕设备写实数字人软件系统动捕设备系统定制化数字人短视频渲染平台,重塑课程教学方式,开展元宇宙沉浸式体验教学活动和参观交流活动。 写实数字人软件系统内置丰富…

【excel】设置可变下拉菜单(一级联动下拉菜单)

文章目录 【需求】制作动态下拉菜单,显示无重复的“班级”列表【思路】设置辅助列,使用UNIQUE()函数去重,并用FILTER()去掉结果中的“0”【步骤】step1 辅助列step2 设置下拉菜单 【总结】 【需求】制作动态下拉菜单,显示无重复的…

你真的会用收藏夹吗?可道云teamOS收藏夹,竟能缩短多层级文件夹的路径,实现快速访问

在日常工作中,我们时常会面临一个让人头疼的问题:如何在海量的文件和资料中快速找到我们需要的那一份? 尤其是在团队协作中,每个人都在不断地上传、更新文件……导致文件目录层级复杂,搜索也变得繁琐。 这时候&#x…

海外短剧APP/H5 系统开发搭建

目前已经有多个客户用我们搭建的海外短剧系统,在使用中已经取得了较高的收益。目前一个客户打算做日本区域的海外短剧项目,需求已经理清楚了,系统正在搭建中

【iOS】UI学习(二)

UI学习&#xff08;二&#xff09; 进度条和滑动条步进器与分栏控件警告对话框和提示等待器UITextFieldUITextField控件UITextFieldDelegate协议 UIScrollView布局子视图手动布局子视图自动布局子视图 进度条和滑动条 下面通过一个程序来讲解该内容&#xff1a; #import <…

go语言基于Gin集成后台管理系统开发定时任务管理cron/v3好用又好看

系统目前是支持两种定时类型&#xff0c;一种是函数类型&#xff0c;一种是接口类型&#xff0c;来支持多样的业务&#xff1b;时间周期可视化选择&#xff0c;方便设定执行周期。框架UI漂亮&#xff0c;添加管理定时任务设置简单&#xff0c;客户都可以做自己调整执行时间周期…

一维时间序列信号的广义傅里叶族变换(Matlab)

广义傅里叶族变换是一种时频变换方法&#xff0c;傅里叶变换、短时傅里叶变换、S变换和许多小波变换都是其特殊情况&#xff0c;完整代码及子函数如下&#xff0c;很容易读懂&#xff1a; % Run a demo by creating a signal, transforming it, and plotting the results% Cre…

flutter开发实战-下拉刷新继续下拉路由进入活动页面实现

flutter开发实战-下拉刷新继续下拉路由进入活动页面实现 很多应用都有首页通过下拉刷新&#xff0c;继续下拉进入新的活动会场进入方式。在Flutter中&#xff0c;也可以通过pull_to_refresh来实现控制刷新页&#xff0c;继续下拉进入新的活动会场页面 一、引入pull_to_refres…

[Redis]List类型

列表类型来存储多个有序的字符串&#xff0c;a、b、c、d、e 五个元素从左到右组成了一个有序的列表&#xff0c;列表中的每个字符串称为元素&#xff0c;一个列表最多可以存储个元素。在 Redis 中&#xff0c;可以对列表两端插入&#xff08;push&#xff09;和弹出&#xff08…

涂装线体智能化管理:RFID技术的典范案例

涂装线体智能化管理&#xff1a;RFID技术的典范案例 汽车涂装是汽车制造过程中极为关键的一环&#xff0c;涉及多道工序&#xff0c;如预处理、电泳、中涂、面漆等&#xff0c;每一步都需要精确控制以确保车身表面的质量和美观。传统方式下&#xff0c;车辆在不同工位间的流转依…