【Redis】Redis主从复制(一)————主从搭建

news2024/12/26 11:26:05

目录

  • 背景
  • 主从复制
    • 主从复制的工作流程
    • 主从复制的优点
  • 配置 redis 主从结构
    • 复制配置文件,修改
    • 配置主从结构
    • 启动 redis 服务
      • 备注
    • 查看复制状态

背景

单节点服务器的问题问题:

  • 可用性:如果这个机器挂了,意味着服务就中断了.
  • 性能:支持的并发量也是比较有限的.

解决思路:引入分布式系统

  • 分布式系统中,往往需要多个服务器来部署 redis 服务,从而构成 redis 集群
  • 此时就可以让这个集群给整个分布式系统中的其他服务,提供更稳定 / 更高效的数据存储功能.

主从复制

  • 主从复制是一种数据同步机制,用于在数据库之间实现数据的自动复制。
  • 在主从复制中,一个数据库(主数据库)被定义为主节点,负责接收和处理所有的写操作;
  • 而其他的数据库(从数据库)被定义为从节点,负责接收和复制主节点的数据更新。
  • 如果是挂掉了某一个从节点,没什么影响,此时继续从主节点或者其他从节点读取数据,效果是完全一样的.
  • 如果改掉的是主节点,是有一定影响的,因为主节点还负责 “写数据”

主从复制的工作流程

  1. 主节点接收到一个写操作。
  2. 主节点将该写操作记录到其日志文件(二进制日志)中。
  3. 通过网络,主节点将该写操作发送给所有的从节点。
  4. 从节点收到该写操作后,将其记录到其日志文件(中继日志)中。
  5. 从节点执行该写操作,并将执行结果返回给主节点。
  6. 主节点将该写操作及执行结果记录到其日志文件中。
  7. 从节点将执行结果发送给客户端。

通过主从复制,可以实现以下几个目的:

  1. 提高数据库的读性能:从节点可以处理读操作,减轻主节点的负载。
  2. 提高数据库的可用性:当主节点发生故障时,可以快速切换到从节点,保证系统的正常运行。
  3. 数据备份:从节点可以作为主节点的备份,以防止数据丢失。

需要注意的是,主从复制只能实现数据的单向复制,即主节点到从节点的复制。如果希望实现数据的双向同步,可以使用主主复制机制。

主从复制的优点

  1. 提高读性能:主从复制可以将读操作分发到从节点上进行处理,减轻主节点的读负载。通过增加从节点的数量,可以进一步扩展读吞吐量,提升系统的性能。

  2. 提高可用性:主从复制可以保证数据库的高可用性。当主节点发生故障时,可以将其中一个从节点提升为新的主节点,使系统继续正常运行而不会中断。

  3. 数据备份:从节点可以用作主节点的备份,保证数据的安全性。主节点的数据变更会被同步到从节点,从而实现数据的备份和恢复。

  4. 负载均衡:通过将读操作和写操作分离到不同的节点上处理,主从复制可以将负载分摊到多个节点上,提高系统的整体性能和吞吐量。

  5. 地理冗余:主从复制还可以用于实现地理冗余。通过将主节点和从节点部署在不同的地理位置上,可以保证在某个地区发生网络故障或自然灾害时,其他地区的节点可以继续提供服务。

配置 redis 主从结构

  • 配置 redis 主从结构,需要启动多个 redis 服务器,分配在一个个单独的主机上(分布式),这里使用一台设备来模拟主从结构
  • redis-server 的端口是 6379 ,此时就不能让其他节点启动时也用 6379 了,我们有一下两种方式来指定 redis-server 的端口号:
    • 启动程序时,通过命令的方式来指定端口号(–port 选项)
    • 直接在配置文件中,来设定端口(推荐,因为修改配置文件,是持久有效的).

复制配置文件,修改

  • 主节点的配置不变,只需要修改从节点的配置即可,因此我们只需要复制两份主节点的配置文件,并修改这两份文件的端口和后台运行方式即可.
    在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

配置主从结构

  • 在两个配置文件末尾加 slaveof 配置主从结构(绑定父节点为 6379 端口).
    在这里插入图片描述

启动 redis 服务

  • 通过 redis-server 命令来启动刚刚配置好的这两个节点.
    在这里插入图片描述

备注

如果 redis 服务启动后修改了配置文件就需要重启才能起效。

  • 如果是通过 redis-server 启动服务器,就必须搭配 kill 命令来停止.

  • 如果是通过 service redis-server start 启动服务器,必须搭配 service redis-server stop 来停止.

  • 如果使用 kill 命令停止 service redis-server start ,这个 redis-server 进程会自动启动.

  • 通过 netstat -anp 命令就可以查看从节点和主节点的绑定情况
    在这里插入图片描述

  • 在复制两个会话,启动两个从节点的 redis 客户端,此时 redis 从节点上就只能读数据,不能写入数据了在这里插入图片描述在这里插入图片描述

查看复制状态

  • 在 redis 客户端,通过 info replication 就可以查看当前节点的复制状态了.
    在这里插入图片描述
  • 在复制两个会话,启动两个从节点的 redis 客户端,此时 redis 从节点上就只能读数据,不能写入数据了
    在这里插入图片描述在这里插入图片描述
  • 值得注意的是,从节点和主节点之间的数据同步,不是瞬间完成的,并且同时主节点上也会 “源源不断” 的收到其他 “修改数据” 的请求
  • 因此这个时候就需要使用 offset 来记录当前主节点和从节点的数据同步情况,当 从节点 的 offset 等于 主节点的 offset 时,表明此时数据完全一致.

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

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

相关文章

探索智慧林业系统的总体架构与应用

背景: 随着人们对森林资源保护和管理的重视,智慧林业系统作为一种新兴的林业管理手段,正在逐渐受到广泛关注和应用。智慧林业系统的总体架构设计与应用,将现代信息技术与林业管理相结合,为森林资源的保护、管理和利用…

创建目录

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 在Python中,os模块提供了两个创建目录的函数,一个用于创建一级目录,另一个用于创建多级目录。 (1&am…

超详解——深入详解Python基础语法——小白篇

目录 1 .语句和变量 变量赋值示例: 打印变量的值: 2. 语句折行 反斜杠折行示例: 使用括号自动折行: 3. 缩进规范 缩进示例: 4. 多重赋值(链式赋值) 多重赋值的应用: 5 .多…

为什么要将Modbus转成MQTT

什么是Modbus Modbus 是一种串行通信协议,最初由Modicon(现在的施耐德电气Schneider Electric)于1979年开发,用于可编程逻辑控制器(PLC)之间的通信。Modbus协议设计简单,易于部署和维护&#xf…

React hooks动态配置侧边栏

React hooks根据不同需求 还有不同的角色 动态的去配置侧边栏 需求: 点击某个按钮是一套侧边栏 ,不同角色(比如管理员之类的权限高一点)比普通用户多个侧边栏 然后点击另一个按钮是另一套侧边栏 此时,就需要动态的去…

安装 JDK 8

安装包 百度网盘 提取码:6666 安装步骤 安装路径不要有中文或者特殊符号如空格等。 双击安装包开始安装。 更改安装路径: 跳出一个页面,安装公共 JRE: 配置环境变量: 配置成功: 去掉自动更新

【教程】从0开始搭建大语言模型:Word和位置Embedding

从0开始搭建大语言模型:Dataset构造 接上文:【教程】从0开始搭建大语言模型:文本预处理 通过滑动窗口进行数据采样 我们要构造输入-目标对来对模型进行训练。 在LLM中,它通过预测文本中的下一个单词进行训练,如下所…

C#操作MySQL从入门到精通(9)——Mysql中的数据类型以及对应的C#中的数据类型

前言 本文介绍Mysql中的数据类型以及每种类型对应的c#中的数据类型 1、整数 bit int tinyint smallint mediumint bigint 2、浮点数 float double decimal 3、日期时间 year time date datetime timestamp 4、字符型 char varchar tinytext text mediumtext longtext …

如何开发一 VSCode 插件

如何开发一个 VSCode 插件,本文开发一个 VSCode “Hello World” 插件,通过代码了解 VSCode 插件是如何工作的。 安装脚手架 npx --package yo --package generator-code -- yo code根据提示选择,插件开发语言选择 TypeScript ? What type…

原力、百度、人人文档下载工具

只可下载可预览的文档,格式为pdf,不能完全保证下载成功,X度与我们既是对手也是朋友。 本文的软件来自的大神,仅供学习交流,不可做它用。 向的大神致敬!!!

信息系统项目管理师0148:输出(9项目范围管理—9.3规划范围管理—9.3.3输出)

点击查看专栏目录 文章目录 9.3.3 输出 9.3.3 输出 范围管理计划 范围管理计划是项目管理计划的组成部分,描述将如何定义、制定、监督、控制和确认项 目范围。范围管理计划用于指导如下过程和相关工作: ①制定项目范围说明书;②根据详细项目范…

在npm发布自己的组件包

目录 前言 正文 npm和git的对比 Node环境的配置 具体发布步骤 ※※需要注意的是 尾声 🔭 Hi,I’m Pleasure1234🌱 I’m currently learning Vue.js,SpringBoot,Computer Security and so on.👯 I’m studying in University of Nottingham Ni…

信息系统项目管理师0149:输入(9项目范围管理—9.4收集需求—9.4.1输入)

点击查看专栏目录 文章目录 9.4 收集需求9.4.1 输入9.4 收集需求 收集需求是为实现目标而确定,记录并管理干系人的需要和需求的过程。本过程的主要作用是为定义产品范围和项目范围奠定基础。本过程仅开展一次或仅在项目的预定义点开展。收集需求过程的数据流向如图 9-2 所示。…

力扣 74.搜索二维矩阵

题目描述: 给你一个满足下述两条属性的 m x n 整数矩阵: 每行中的整数从左到右按非严格递增顺序排列。每行的第一个整数大于前一行的最后一个整数。 给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则&am…

【MMU】——ARM 二级页表

文章目录 二级页表项即 entry 的格式如下 二级页表项有三种类型 产生中止异常的故障条目。这可能是预取或数据中止、取决于访问类型。这实际上表示虚拟地址未映射 bit[1:0] 00大页 64KB。bit[1:0] 01。小页 4KB。bit[1:0]1x。 一级页表占用 16KB 的内存,二级页表…

攻防世界---misc---Hear-with-your-Eyes

1、题目描述,下载附件,是一个.gz后缀的文件,查找资料发现,这个后缀是Linux系统的压缩包后缀。这里题目提示了用眼睛听音频,说明会有个音频,并且信息就在音频,可以用眼睛看到 2、将文件放在linux…

警务反诈RPA:利用机器人流程自动化技术打击诈骗行为

信息时代,网络技术快速发展,在丰富生活的同时,也带来了持续高发的电信网络诈骗问题,对社会造成了严重威胁。面对海量的数据信息,传统数据融合技术的瓶颈不断显现,无法满足风险防控、打击诈骗的效率要求&…

使用 Spring Boot 开发邮件系统

文章目录 使用 Spring Boot 开发邮件系统邮件发送流程简单使用第 1 步:pom 包配置第 2 步:配置文件163 邮箱配置126 邮箱配置QQ 邮箱配置如下:开启 POP 3 / SMTP 服务、IMAP / SMTP 服务开通设置客户端授权密码 第 3 步:文本邮件发送第 4 步&…

L45---506.相对名次(java)--排序

1.题目描述 2.知识点 (1)String.join(" ", words) 是 Java 中的一个语法,用于将数组或集合中的元素连接成一个单独的字符串,连接时使用指定的分隔符。这里的 " " 是作为分隔符使用的一个空格字符串。 Strin…

Bond 网卡绑定技术学习

前言: 为了实现网卡的高可用性,需要学习一下 Bond技术 1. 概念 Bond(也被称为链路聚合、端口绑定或接口绑定)是一种网络技术,用于将多个物理网络接口(如以太网接口)组合成一个逻辑接口。这样做…