Redis 持久化

文章目录

  • 1. Redis 持久化
  • 2. RDB
    • 2.1 自动触发
    • 2.2 手动触发
    • 2.3 RDB 优点
    • 2.4 RDB 缺点
    • 2.5 RDB 文件修复
    • 2.6 总结
  • 3. AOF
    • 3.1 AOF持久化工作流程
    • 3.2 AOF 缓冲区三种写回策略
    • 3.3 AOF 优点
    • 3.4 AOF 缺点
    • 3.5 AOF 重写机制
    • 3.6 AOF 重写原理
    • 3.7 总结
  • 4. 混合持久化
  • 5. 纯缓存模式

1. Redis 持久化


Redis 持久化官方解释 : Redis persistence | Redis


简单来说 持久化技术 就是 将 内存中的数据写入硬盘中 .


关于 Redis 持久化 主要使用到两种手段

  1. RDB
  2. AOF


注: 这两种方法是可以混合使用的.


图 : 对两种方法的简单理解

在这里插入图片描述

2. RDB


在这里插入图片描述

光看文字可能还是 很糊涂, 下面通过 代码案例来 彻底了解他 .

在这里插入图片描述

代码演示:

关于 RDB 的操作 有 两种

  1. 自动触发
  2. 手动触发


这里先来看自动触发

2.1 自动触发


图一 : 修改配置文件

在这里插入图片描述


图二 :

在这里插入图片描述


图三 :

在这里插入图片描述


图四 :

在这里插入图片描述


图五 :

在这里插入图片描述

2.2 手动触发


当前我们是 5 秒钟 2 次修改 就 自动触发 去生成 dump.rdb 文件 这里数据备份是非常频繁的 , 在实际生产中 不可能是这样的, 假设 10 分钟 100次 , 突然有一个 数据非常重要 , 但是还没有到 100 次 修改 , 想要立刻的备份 就可以 手动触发 ,让他生成 一份 dump.rdb 文件.


关于手动触发涉及到两个命令 :

  1. save
  2. bgase


关于 save 和 bgase 操作 , 相当于 多开了一个子进程 去完成 dump6379的书写.

在这里插入图片描述


关于 save 和 bgsave 就是开启一个子进程 去完成备份 ,那么请问这里 为啥 会 出现两个 命令 ?


关于 save 和 bgsave 的区别 :


在生产中 只允许 使用 bgsave 不允许使用 save ,因为 使用 save 的时候 在主程序 执行 会阻塞 当前 redis 服务器 ,直到 持久化 工作完成执行 save 命令期间 ,Redis 不会处理其他命令 , 线上禁止使用


save 案例

在这里插入图片描述


bgsave


Redis 会在后台异步进行快照操作 , 不阻塞 快照同时还可以响应客户端请求 , 该触发方式会 fork 一个子进程 有子进程复制持久化过程.


Redis 使用 bgsave 对当前内存中的所有数据做快照 , 这个操作是子进程在后台完成的 ,这就允许主进程同时可以修改数据.


演示 :

在这里插入图片描述


补充 : 这里我们可以通过 lastsave 命令 获取最后一次成功执行 快照的时间


演示 :

在这里插入图片描述

2.3 RDB 优点


在这里插入图片描述

2.4 RDB 缺点


在这里插入图片描述

2.5 RDB 文件修复

在这里插入图片描述

2.6 总结

那些方式会触发 RDB 快照

  1. 配置文件中默认的快照配置 (满足就触发)
  2. 手动 执行 save / bgsave 命令
  3. 执行 flushall / flushdb 命令 也会产生 dump.rdb 文件 ,但是里面是空的无意义
  4. 执行 shutdown 且没有设置开启 AOF 持久化
  5. 主从复制时 , 主节点自动触发


注意 : 关于 第 5 点 ,在说到 主从复制时 会说到.


如果禁用 快照

  1. 动态所有停止 RDB 保存规则的方法 : redis-cli config set save “”

  2. 配置文件快照禁用 :

在这里插入图片描述

RDB 优化配置项

在这里插入图片描述


小总结 :

在这里插入图片描述

3. AOF

在这里插入图片描述

3.1 AOF持久化工作流程


在这里插入图片描述

3.2 AOF 缓冲区三种写回策略

三种写回策略 :

  1. Always : 同步写回 , 每个写命令执行完立刻同步地将日志写回到磁盘
  2. everysec : 每秒写回 , 每个写命令执行完,只是先把日志写道 AOF 文件的内存缓冲区 , 每个 1 秒把缓冲区的内容写入磁盘
  3. no : 操作系统控制的协会,每个协会命令执行完 ,只是先把日志写道 AOF 的内存缓冲区, 由操作系统决定何时将缓冲区内容写回磁盘.

在这里插入图片描述


关于这三种写回策略 :

在这里插入图片描述


关于 AOF 的一些配置项


图一 :

在这里插入图片描述


图二 :

在这里插入图片描述


图三 :

在这里插入图片描述


注意 : 这里 dir 路径设置有误需要改为 dir /myredis/

在这里插入图片描述


上面这些配置项 看完 接下来就来看代码案例 :


正常数据恢复


图一 :

在这里插入图片描述


图二 :

在这里插入图片描述


图三 :

在这里插入图片描述


异常恢复


图一 :

在这里插入图片描述


图二 :

在这里插入图片描述

3.3 AOF 优点


在这里插入图片描述


关于 AOF 的优点 简单一句话 : 更好的保护数据不丢失 , 性能高,可做紧急恢复.

3.4 AOF 缺点


在这里插入图片描述

3.5 AOF 重写机制


AOF 重写机制是什么 ?


由于AOF持久化是Redis不断将写命令记录到 AOF 文件中,随着Redis不断的进行,AOF 的文件会越来越大,

文件越大,占用服务器内存越大以及 AOF 恢复要求时间越长。


为了解决这个问题,Redis新增了重写机制,当AOF文件的大小超过所设定的峰值时,Redis就会自动启动AOF文件的内容压缩,

只保留可以恢复数据的最小指令集 或者 可以手动使用命令 bgrewriteaof 来触发。

一句话 : 启动 AOF 文件的 内容压缩 ,只保留可以恢复数据的最小指令集

关于 AOF 的 重写触发机制 :

关于 AOF 的重写触发机制有两种 :

  1. 自动触发
  2. 手动触发


图一 :

在这里插入图片描述


图二 :

在这里插入图片描述


手动触发 :

3.6 AOF 重写原理

1: 在重写开始前,redis会创建一个“重写子进程”,这个子进程会读取现有的AOF文件,并将其包含的指令进行分析压缩并写入到一个临时文件中。

2: 与此同时,主进程会将新接收到的写指令一边累积到内存缓冲区中,一边继续写入到原有的AOF文件中,这样做是保证原有的AOF文件的可用性,

避免在重写过程中出现意外。

3: 当“重写子进程”完成重写工作后,它会给父进程发一个信号,父进程收到信号后就会将内存中缓存的写指令追加到新AOF文件中

4: 当追加结束后,redis就会用新AOF文件来代替旧AOF文件,之后再有新的写指令,就都会追加到新的AOF文件中

5: 重写aof文件的操作,并没有读取旧的aof文件,而是将整个内存中的数据库内容用命令的方式重写了一个新的aof文件,这点和快照有点类似

3.7 总结


AOF 优化配置项 : 配置文件 APPEND ONLY MODE 模块

在这里插入图片描述


小总结 :

在这里插入图片描述

4. 混合持久化


配置文件 :

在这里插入图片描述


通过配置文件 我们可以知道 RDB 和 AOF 是可以同时存在的 ,当 RDB 和 AOF 同时存在时 ,会优先加载 AOF 文件 .


面试题 : 数据恢复和加载流程


在同时开启 rdb 和 aof 持久化时 ,重启时只会加载 aof 文件 ,并不会加载 rdb 文件.

在这里插入图片描述


提问 : 关于 RDB 和 AOF 两种持久化方式 你觉得用那个 ?


这里先来看看 RDB 和 AOF 的特征 :

  1. RDB 持久化方式能够在指定的时间间隔能对你的数据进行快照存储
  2. AOF持久记录每次对服务器写的操作,当服务器重启的时候会重新执行这些命令来恢复原始的数据,AOF命令以 redis 协议追加保存每次写的操作到文件末尾.


在 RDB 和 AOF 都存在的情况下 ,当 redis 重启的时候 ,会优先载入 AOF 文件来恢复原始数据 , 因为 在通常情况下 AOF 文件保存的数据集 要比 RDB 文件保存

的数据集要完整 .


RDB的数据不实时 , 同时两者服务器重启也只会找 AOF 文件 ,那要不只是用AOF 呢?

作者建议不要 (redis 作者) , 因为 DB 更适合用于备份数据库 (AOF 在不断变化不好备份) , 留这 RDB 作为一个万一的手段 .


所以 : 这里推荐使用 RDB 和 AOF 的混合方式.


关于 RDB 和 AOF 混合方式的优点 : 既能快速加载又能避免丢失过多的数据.


这两种方式混合就有点像 :鸳鸯锅

在这里插入图片描述


下面我们就来配置文件中开启混合 :

在这里插入图片描述

5. 纯缓存模式


redis 是一个 基于 key-value 键值对的内存数据库 ,最主要的功能是做缓存 , 如果 开启 RDB , AOF 或多或少会分走一些资源 .

这里我们想要达到 纯缓存模式 (不要持久化了) 就可以 同时关闭 RDB + AOF , 达到性能的提升.

  1. 禁用 RDB : 在配置文件中 找到 save 将他设置为 “” 即可 .

在这里插入图片描述

注意 : 禁用 rdb 持久化模式下 ,我们仍然可以使用命令 save , bgsave 生成 rdb 文件

2. 禁用 AOF : 在配置文件中 找到 appendonly 设置为 no 即可.

在这里插入图片描述


注意 : 禁用 aof 持久化 模式下, 我们仍然可以使用命令 bgrewriteaof 生成 aof 文件

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

系统移植——linux内核移植——分析内核编译过程

uImage镜像文件 1.进入linux内核源码目录 ubuntuubuntu:~$ cd FSMP1A/linux-stm32mp-5.10.61-stm32mp-r2-r0/linux-5.10.61/ 打开Makefile文件 vi Makefile 搜索include 因为 $(SRCARCH)->arm 所以上述指令为 arch/arm/Makefile 2.进入linux内核源码目录下,arch/arm目录下…

计网笔记 数据链路层 (1-2) 封装成帧、差错控制、流量控制与可靠传输、停止等待协议、后退N帧协议(GBN)、选择重传协议(SR)

文章目录 前言在这里插入图片描述 零、数据链路层基本概念一、功能0、数据链路层功能概述1、封装成帧和透明传输1.1封装成帧1.2 透明传输1.3组帧方法 2、数据链路层的差错控制2.0差错从何而来2.1位错(比特错,1变成0,0变成1)2.2帧错…

复习一周,面了京东和百度,不小心都拿了Offer...

我个人情况是5年软件测试经验,在家复习了一周,面了京东和百度,都顺利拿下offer,下面是我的面试经历分享,希望能带来一些不一样的启发和帮助。 两家公司最常问的就是下面这些问题: 请介绍一下你之前做过哪些…

String类

目录 一.认识 String 类 二.常用方法 1.字符串构造(定义) 2.字符串指为空和null 3.String对象的比较 (1)equals和的区别 (2)compareTo比较 4.字符串查找 5.字符串转化 (1)…

前几天面了个32岁的测试员,年薪50w问题基本都能回答上,应该刷了不少八股文···

互联网行业竞争是一年比一年严峻,作为测试工程师的我们唯有不停地学习,不断的提升自己才能保证自己的核心竞争力从而拿到更好的薪水,进入心仪的企业(阿里、字节、美团、腾讯等大厂.....) 所以,大家就迎来了…

centerpoint论文和代码解读

目录 一、序论 二、论文结构 三、代码 论文地址: https://arxiv.org/pdf/2006.11275.pdf 代码地址:tianweiy/CenterPoint (github.com) 一、序论 centorpoint是一种anchor-free的方法,直接预测物体的中心点,然后直接回归其wh…

【C++】unordered_map与unordered_set(系列关联式容器)

文章目录 1.unordered系列关联式容器2. unordered_map3.unordered_set 1.unordered系列关联式容器 在C98中,STL提供了底层为红黑树结构的一系列关联式容器,如map和set,它们在查询时效率可达logN,即最差情况下需要比较红黑树的高度…

将 Segment Anything 扩展到医学图像领域

文章目录 前言技术交流SAM 拆解分析从医学角度理解 SAM 的效用MedSAM实验总结 前言 SAM 是一种在自然图像分割方面取得成功的模型,但在医学图像分割方面表现不佳。MedSAM 首次尝试将 SAM 的成功扩展到医学图像,并成为用于分割各种医学图像的通用工具。为…

一文读懂 DNS 解析

导读 文章为“一文读懂域名与网站系列”第二篇,上篇文章主要介绍了域名的注册、建站和管理,通过本文你可以了解以下几个问题: 域名的结构、常用解析记录的类型 DNS 解析的过程 DNS 解析拓展知识 众所周知,互联网中的地址其实是…

Invicti v23.5 for Windows 发布 - 企业应用安全测试

Invicti v23.5 for Windows - 企业应用安全测试 Invicti Standard 11 May 2023 v23.5.0.40516 请访问原文链接:https://sysin.org/blog/invicti/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org Invicti 是一种自动…

ESP32在linux下烧录,提示权限有问题,解决方法

执行idf.py -p /dev/ttyACM0 flash下载时,提示这个错误 serial.serialutil.SerialException: [Errno 13] could not open port /dev/ttyACM0: [Errno 13] Permission denied: /dev/ttyACM0 解决方法: 1检查串行端口 /dev/ttyUSB0 是否已被其他程序占用…

系统分析师之项目管理(十七)

一、范围管理 范围管理:确定项目的边界,即哪些工作是项目应该做的,哪些工作不应该包括在项目中。 二、时间管理 时间管理:也叫进度管理,就是用科学的方法,确定目标进度,编制进度计划和资源供应计…

SpringBoot整合Swagger

Swagger的作用&#xff1a;生成前后的接口文档&#xff1a; 了解Swagger的概念及作用 掌握在项目中集成Swagger自动生成API文档 一、SpringBoot集成Swagger 1.依赖&#xff1a; <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 --><depe…

【A、B、C、D、E类IP地址划分依据,你都会吗?】

IP 地址的格式&#xff1a;IP 地址 网络地址 主机地址 如果 IP 进行了子网划分&#xff1a; 则IP地址网络地址子网地址主机地址 网络地址是互联网上的节点在网络中具有的逻辑地址。MAC 地址&#xff0c;处于数据链 路层&#xff0c;IP 地址处于网络层&#xff0c;端口号处…

人工智能基础部分15-自然语言处理中的数据处理上采样、下采样、负采样是什么?

大家好&#xff0c;我是微学AI&#xff0c;今天给大家介绍一下人工智能基础部分15-自然语言处理中的数据处理上采样、下采样、负采样是什么&#xff1f;在自然语言处理中&#xff0c;上采样、下采样、负采样都是用于处理数据不平衡问题的技术&#xff0c;目的是为了优化模型的训…

C# 对PdfiumViewer工具栏进行自定义,实现放大缩小,首页, 尾页,上一页等功能。

文章目录 前言PdfiumViewer工具栏扩展1 创建winform工程&#xff0c;UI界面2 打印预览3 放大功能4 缩小功能5 按比例缩放6 全屏7 首页和尾页8 上一页和下一页9 页码输入框10 显示当前预览的页码 小结 前言 关于PdfiumViewer的介绍 C# 使用PdfiumViewer实现对PDF文档打印预览&a…

路径规划算法:基于麻雀优化的路径规划算法- 附代码

路径规划算法&#xff1a;基于麻雀优化的路径规划算法- 附代码 文章目录 路径规划算法&#xff1a;基于麻雀优化的路径规划算法- 附代码1.算法原理1.1 环境设定1.2 约束条件1.3 适应度函数 2.算法结果3.MATLAB代码4.参考文献 摘要&#xff1a;本文主要介绍利用智能优化算法麻雀…

Qt使用星空图作为窗口背景,点击键盘的WASD控制小飞机在上面移动。

事件函数的使用依托于Qt的事件机制&#xff0c;一个来自于外部事件的传递机制模型如下所示 信号槽虽然好用&#xff0c;但是无法包含所有的情况&#xff0c;事件函数可以起到对信号槽无法覆盖的一些时机进行补充&#xff0c;事件函数的使用无需连接。 常用的事件函数如下所示。…

【Mysql实战】使用存储过程和计算同比环比

背景 同环比&#xff0c;是基本的数据分析方法。在各类调研表中屡见不鲜&#xff0c;如果人工向前追溯统计数据&#xff0c;可想而知工作量是非常大的。 标题复制10行&#xff0c;并且每行大于10个字符【源码解析】SpringBoot接口参数【Mysql实战】使用存储过程和计算同比环比…

vite跨域问题,你可能需要看这篇文章

最近在学习项目的时候&#xff0c;使用了vite工具进行构建&#xff0c;然后出现了跨域的问题&#xff0c;中间的曲折不过多叙述&#xff0c;直接进入正题。 前端成功启动后的界面&#xff1a; 然后在后端进行的Controller上使用了如下的配置 然后浏览器就会出现跨域的问题 为什…