【Redis从0到1进阶】Redis 持久化

news2025/1/23 9:29:19

笔记内容来自B站博主《遇见狂神说》:Redis视频链接

Redis 是内存数据库,如果不将内存中的数据库状态保存到磁盘,那么一旦服务器进程退出,服务器中的数据库状态也会消失。所有Redis 提供了持久化功能!

一、RDB(Redis DataBase)

什么是RDB

RDB 全称是 Redis DataBase,简而言之,就是在不同的时间点,将 redis 存储的数据生成快照并存储到磁盘等介质上。就是Redis的数据库。
在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是Snapshot快照,它恢复时是将快照文件直接读到内存里。
Redis 会创建(fork)一个子进程来进行持久化,会先将数据写入到一个临时文件中,待持久化过程都结束了,再用这个临时文件替换上次持久化好的文件。整个过程中,主进程是不进行任何IO操作的。这就确保了极高的性能。如果需要进行大规模数据的恢复,且对于数据恢复的完整性不是非常敏感,那么RDB方式要比AOF方式更加的高效。
RDB的缺点是最后一次持久化后的数据可能丢失。
在这里插入图片描述

测试rdb

1、简单配置一下配置文件

rdb保存的文件默认是dump.rdb 可以在配置文件中配置。
在这里插入图片描述
先修改配置文件,注释掉默认的。设置60s内修改了3次key,就会触发rdb操作。
在这里插入图片描述
rdb保存的路径 /var/lib/redis
在这里插入图片描述

修改保存!需要重启redis服务,和删除rdb文件!!!

2、测试生成rdb文件

先删除 rdb 文件
在这里插入图片描述
这里我们set 三个值
在这里插入图片描述
60秒内修改了三次key, 触发rdb操作,生成dump.rdb文件
在这里插入图片描述

3、触发机制

1、save的规则满足情况下,会自动触发rdb规则
2、执行flush命令,
3、退出redis
备份就自动生成一个dump.rdb

4、恢复rdb文件

1、只需要将rdb文件放在我们redis启动目录就可以,redis启动的时候会自动检查dump.rdb 恢复其中的数据。
2、查询需要存在的位置。

127.0.0.1:6388> config get dir	# 获取配置文件中的 dir 属性
1) "dir"
2) "/var/lib/redis"	# 如果在这个目录下存在dump.rdb文件,启动就会自动恢复其中的数据

5、总结

Redis 的 rdb 默认配置几乎够我们自己使用了,但是我们还是需要学习
rdb的优缺点

优点:
1、适合大规模的数据恢复
2、对数据的完整性要求不高

缺点:
1、需要一定的时间间隔进程操作,如果redis意外宕机了,这个最后一次修改数据就没有的了
2、fork进程的时候,会占用一定的内容空间

图片取自redis中文网:
在这里插入图片描述

二、AOF(Append Onley File)

AOF,英文是 Append Only File,即只允许追加不允许改写的文件。
aof将我们的所有命令都记录下来,相当于历史记录(history),恢复的时候就把这个文件全部在执行一遍

什么是AOF

以日志的形式来记录每个写操作,将Redis执行过的所有指令记录下来(读操作不记录),只许追加文件但不可以改写文件,redis启动之初会读取该文件重新构建数据,换言之,redis重启的话就根据日志文件的内容将写指令从前到后执行一次以完成数据的恢复工作
在这里插入图片描述

1、append 配置文件

aof 默认是关闭的,报错的文件名为 appendonly.aof。 我们只需要把appendonly设置为yes就可以,其他保持默认状态已经够用。
在这里插入图片描述

重启redis就可以看到 appendonly.aof 文件
在这里插入图片描述

2、测试写入数据

首先我们在客户端set几个key

127.0.0.1:6388> flushdb	# 清除当前数据库
OK
127.0.0.1:6388> set name oldfe	# 这里我 set 三个key
OK
127.0.0.1:6388> set age 16
OK
127.0.0.1:6388> set city beijing
OK

然后我们查看一下aof文件

root@VM-20-10-ubuntu:/var/lib/redis# cat appendonly.aof 	# 使用 cat 查看文件内容
*2				# 这表示接下来有 2 个参数。 《select 0》
$6				# 接下来字符串的长度。《select》
SELECT			# 首先是我们的查询,默认查询当前数据库(下标为0的数据库)
$1				# 接下来字符串的长度。《0》
0				# 这是数据库的索引号,这里表示选择第一个数据库。
*3				# 这表示接下来有 3 个参数。《set name oldfe》
$3				
set				# 这是我们刚刚执行的命令。《set name oldfe》
$4
name			
$5
oldfe
*3
$3
set				# 这是我们刚刚执行的命令。《set age 16》
$3
age
$2
16
*3
$3
set				# 这是我们刚刚执行的命令。《set city beijing》
$4
city
$7
beijing

3、破坏aof文件进行测试启动

首先我们随便修改一下,破坏完好的数据。
在这里插入图片描述
然后进行redis重启,发现启动失败!因为aof文件有错位!这时候redis是启动不起来的。
在这里插入图片描述
莫慌,redis 提供修复工具 redis-check-aof
ubuntu系统上redis默认安装在 /usr/bin 目录下
在这里插入图片描述
使用aof工具进行修复

# 修复指定aof文件
redis-check-aof --fix /var/lib/redis/appendonly.aof

在这里插入图片描述
重启 redis。启动成功!
在这里插入图片描述
aof修复机制其实就是把错误的数据删除。我们再次查看修复好的aof 文件,发现错误的数据被删除。
在这里插入图片描述

4、总结

配置文件中 aof 的其他配置

appendonly no	# 默认是不开启aof模式,默认是使用rdb方式持久化,在大部分情况下,rdb完全够用
appendfilename "appendonly.aof"	 # 持久化的文件名

# appendfsync always	# 每次修改都会sync,消耗性能
appendfsync everysec	# 每秒执行一次,默认状态。可能会丢失这1s的数据
# appendfsync no	# 不执行 sync, 这个时候操作系统自己同步数据,速度最快

# 这个参数指定了在 AOF 文件当前大小超过上一次重写后大小的百分比增长时,触发自动 AOF 重写。
# 例如,如果设置为 100,则表示当 AOF 文件大小增长到上一次重写后大小的两倍时,触发自动 AOF 重写。
# 这有助于控制 AOF 文件的增长速度,以避免文件过大而影响性能。
auto-aof-rewrite-percentage 100

# 这个参数指定了进行自动 AOF 重写的最小 AOF 文件大小阈值。只有当当前 AOF 文件大小超过这个阈值时,
# 才会考虑触发自动 AOF 重写。在你的例子中,设置为 64mb 表示 AOF 文件必须达到 64MB 大小才会考虑进行自动重写。
auto-aof-rewrite-min-size 64mb

aof的优缺点:

优点:
1、每一次修改都同步,文件的完整会更加好
2、每秒同步一次,可能会丢失一秒的数据
3、从不同步、效率最高

缺点:
1、相对于数据文件来说,aof远远大于rdb,修复的速度也比rdb慢
2、aof运行效率也要比rdb慢,所以我们redis默认的配置就是rdb持久化

图片取自Redis中文网:
在这里插入图片描述

5、扩展。

1、RDB 持久化方式能够在指定的时间间隔内对你的数据进行快照存储
2、AOF 持久化方式记录每次对服务器写的操作,当服务器重启的时候会重新执行这些命令来恢复原始的数据,AOF命令以Redis 协议追加保存每次写的操作到文件末尾,Redis还能对AOF文件进行后台重写,是的 AOF文件的体积不至于过大。
3、只做缓存,如果你只希望你的数据在服务器运行的时候存在,你也可以不使用任何持久化
4、同时开启两种持久化方式

  • 在这种情况下,当Redis 重启的时候会优先载入AOF文件来恢复原始的数据,因为在通常情况下AOF文件保存的数据集要比RDB文件保存的数据集要完整。
  • RDB的数据不实时,同时使用两者时服务器重启也只会找AOF文件,那要不要只使用AOF呢?作者建议不要,因为RDB更适合用户备份数据库(AOF在不断变化不好备份),快速重启,而且不会有AOF可能潜在的Bug,留着作为一个万一的手段。

5、性能建议

  • 因为RDB文件只用作后备用途,建议只在Slave上持久化RDB文件,而且只要15分钟备份一次就够了,只保留save 900 1 这条规则。
  • 如果Enable AOF,好处是在最恶劣情况下也只会丢失不超过两秒的数据,启动脚本较简单只load自己的AOF文件就可以了,代价一是带来了持续的IO,二是AOF rewrite的最后将 rewrite过程中产生的新数据写到新文件造成的阻塞几乎是不可避免的。只要硬盘许可,应该尽量减少AOF rewrite 的频率,AOF重写的基础大小默认值64M太小了,可以设到5G以上,默认超过原大小100% 大小重写可以改到适当的数值。
  • 如果不 Enable AOF,仅靠Master-Slave Repllcation(复制) 实现高可用性也可以,能省掉一大笔IO,也减少了rewrite时带来的系统波动,代价是如果Master/Slave同时断电,会丢失十几分钟的数据,启动脚本也要比较两个Master/Slave中的RDB文件,载入较新的那个,微博就是这种架构。

温馨提示!!!

测试完成后记得把配置文件恢复默认!!!

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

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

相关文章

pixelRNN与pixelCNN

目的:为了找到一个最能解释得到的生成样本的模型 PixelRNN 我们需要利用概率链式法则将图像x的生成概率转变为每个像素生成概率的乘积,也就是每个通道生成概率的乘积。 公式: 公式解释:p(x)是每个图像x的概率;右侧为…

一文快速接入银行卡识别API

银行卡识别API 能通过机器学习和图像识别技术来解析银行卡相关信息,根据用户上传卡片自动识别内容,返回该卡的卡号、所属银行及银行类型等信息。可以在用户需要输入银行卡等相关信息时使用该功能,帮助用户快速输入正确信息,简化用…

PE文件(十一)移动导出表和重定位表

移动表的原因 一个PE文件中有很多节,每个节都存储不同的数据。而PE文件中的各种表也都分散存储在这些节当中。此时各种表的信息与程序的代码和数据相互混合在一起,如果我们直接对整个程序进行加密,那系统在初始化程序时就会出问题。比如&…

2024年7月9日~2024年7月15日周报

目录 一、前言 二、完成情况 2.1 特征图保存方法 2.1.1 定义网络模型 2.1.2 定义保存特征图的钩子函数 2.1.3 为模型层注册钩子 2.1.4 运行模型并检查特征图 2.2 实验情况 三、下周计划 一、前言 本周的7月11日~7月14日参加了机器培训的学习讨论会,对很多概…

iredmail服务器安装步骤详解!如何做配置?

iredmail服务器安全性设置指南?怎么升级邮件服务器? iredmail是一个功能强大的邮件服务器解决方案,它集成了多个开源软件,使您能够快速部署和管理邮件服务。AokSend将逐步引导您完成安装过程,无需深入的编程知识即可轻…

springboot的Filter过滤器拦截资源

配置拦截器,要加上ServletComponentScan和WebFilter(urlPatterns "/*")注解一起使用

基于Java的斗地主游戏案例开发(做牌、洗牌、发牌、看牌

package Game;import java.util.ArrayList; import java.util.Collections;public class PokerGame01 {//牌盒//♥3 ♣3static ArrayList<String> list new ArrayList<>();//静态代码块//特点&#xff1a;随着类的加载而在加载的&#xff0c;而且只执行一次。stat…

如何评估代理的可靠性和安全性

使用IP代理最主要的是要看是否安全&#xff0c;代理IP是否稳定可靠&#xff0c;但是又如何评估一个代理IP的安全性与可靠性呢&#xff0c;下面具体介绍一下。 评估代理的可靠性 服务稳定性 代理服务的稳定性直接影响到业务的连续性和效率。评估代理的服务稳定性重点查看下面…

vue2学习笔记1-官网使用指南和搭建开发环境

官网使用指南 官网地址&#xff1a;介绍 — Vue.js 1、学习 1.1 教程和API 最重要的两个板块。API是VUE的字典&#xff0c;需要时来查阅。 1.2、风格指南 如何写出风格优雅的VUE代码。规则分为四类&#xff1a;必要的&#xff0c;强烈推荐、推荐、谨慎使用。 1.3、示例 …

正点原子STM32(基于HAL库)6

目录 TFTLCD&#xff08;MCU 屏&#xff09;实验TFTLCD 简介TFTLCD 简介液晶显示控制器FSMC 简介FSMC 关联寄存器简介 硬件设计程序设计FSMC 和SRAM 的HAL 库驱动程序流程图程序解析 下载验证 LTDC LCD&#xff08;RGB 屏&#xff09;实验RGBLCD<DC 简介RGBLCD 简介LTDC 简介…

使用Keepalived实现双机热备(虚拟漂移IP地址)详细介绍

&#x1f3e1;作者主页&#xff1a;点击&#xff01; &#x1f427;Linux基础知识(初学)&#xff1a;点击&#xff01; &#x1f427;Linux高级管理防护和群集专栏&#xff1a;点击&#xff01; &#x1f510;Linux中firewalld防火墙&#xff1a;点击&#xff01; ⏰️创作…

影响代理运行速度的因素有哪些?

在当今数字化时代&#xff0c;代理服务器被广泛应用于网络接入、数据收集、隐私保护等各种场景。然而代理服务器的运行速度对用户体验和运行效率至关重要。在本文中&#xff0c;我们将讨论影响代理运行速度的主要因素&#xff0c;并介绍如何优化代理服务器以提高运行速度。 第一…

解决ESLint和Prettier冲突的问题

在配置了ESLint的项目中使用Prettier进行格式化可能会出现冲突&#xff0c;不如Prettier配置了使用双引号&#xff0c;ESLint配置了单引号&#xff0c;当然可以一个一个改成一样的配置&#xff0c;但是比较麻烦。我发现可以直接使用ESLint的规则进行格式化。在VSCode配置过程如…

【Orange Pi AIpro测评】基于OrangePi AIpro开发板从零搭建部署小雅影音库

文章目录 一、OrangePi AIpro介绍1.1 OrangePi AIpro 实物图1.2 OrangePi AIpro 示意图1.3 OrangePi AIpro详细信息介绍 二、为 OrangePi 安装 xfce4 桌面及 VNC 服务三、将 Ubuntu 镜像烧写到 TF 卡四、将 Ubuntu 镜像烧写到 NVMe SSD五、远程连接OrangePi AIpro的方式5.1 通过…

[C/C++入门][变量和运算]7、交换变量(空杯思想)

计算机中交换变量的值&#xff0c;可谓是非常常见&#xff0c;常见到几乎考试卷子里都有它。 如图&#xff0c;一杯牛奶&#xff0c;一杯咖啡&#xff0c;如何进行交换呢&#xff1f; 相信懂的都懂&#xff0c;不懂的看完这个图也就懂了。 生活中非常简单的例子&#xff0c;放…

新160个crackme - 003-Cruehead-CrackMe-3

运行分析 发现只有一个退出 PE分析 32位&#xff0c;未知程序&#xff0c;壳未知 静态分析 发现关键字符串 找到关键函数&#xff0c;分析函数&#xff0c;设置断点 动态调试 到断点到if语句&#xff0c;tab键切换至汇编代码 找到跳转语句 右键Assemble jnz改为jz然后回…

Matlab 判断直线上一点

文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 判断一个点是否位于一直线上有很多方法,这里使用一种很有趣的坐标:Plucker线坐标,它的定义如下所示: 这个坐标有个很有趣的性质,我们可以使用Plucker坐标矢量构建一个Plucker矩阵: 则它与位于对应线上的齐次点…

LaTeX教程(015)-LaTeX文档结构(15)

LaTeX教程(015)- LaTeX \LaTeX LATE​X文档结构(15) 2.4 管理引用 LaTeX \LaTeX LATE​X有一些命令能够很容易的管理文档中的引用。它支持交叉引用(cross-references&#xff0c;文档内部对象的引用)&#xff0c;文献引用(bibliographic&#xff0c;对外部文档的引用)&#xf…

【UNI-APP】阿里NLS一句话听写typescript模块

阿里提供的demo代码都是javascript&#xff0c;自己捏个轮子。参考着自己写了一个阿里巴巴一句话听写Nls的typescript模块。VUE3的组合式API形式 startClient&#xff1a;开始听写&#xff0c;注意下一步要尽快开启识别和传数据&#xff0c;否则6秒后会关闭 startRecognition…

AndroidStudio 删除未使用的资源精简apk体积

历史项目开发下来&#xff0c;会有很多未使用的类、布局xml 、资源文件等。 未使用的图片资源&#xff0c;会增大apk体积。 为了精简应用&#xff0c;需要去掉。 查找未使用的资源 Code – Analyze Code – Run Inspection by Name 输入 Unused 会有提示 选择要查找的目录…