Redis的几种持久化方式

devtools/2024/11/28 3:59:54/

Redis 提供了两种主要的持久化方式,它们分别是:

1. RDB(Redis Database Snapshotting)

RDB 是 Redis 的一种数据持久化方式,它会在指定的时间间隔内对 Redis 中的数据进行快照并保存到硬盘上。

特点:
  • 触发方式:RDB 持久化通常是在满足一定条件时触发的(比如,经过一定数量的写操作或一定的时间间隔后)。
  • 存储方式:RDB 会创建一个包含当前所有数据库数据的快照文件(通常是 dump.rdb),该文件会被保存在磁盘上。
  • 性能:RDB 的写入操作是非阻塞的,不会影响 Redis 的响应性能,因此适用于需要高性能写入的场景。
  • 恢复速度:RDB 快照的恢复速度较快,适合用来恢复大量数据。
  • 数据丢失:RDB 持久化的最大问题是如果 Redis 宕机,可能会丢失自上次快照以来的所有数据(因为它不会记录每个操作,只记录在快照时的数据状态)。
配置:

可以通过 redis.conf 文件中的 save 配置项来设定生成快照的条件,例如:

save 900 1   # 在 900 秒内至少发生 1 次写操作时生成快照
save 300 10  # 在 300 秒内至少发生 10 次写操作时生成快照
save 60 10000 # 在 60 秒内至少发生 10000 次写操作时生成快照

2. AOF(Append Only File)

AOF 是另一种 Redis 的数据持久化方式,它会将 Redis 执行的每一个写操作记录到一个日志文件中,以此来实现持久化。

特点:
  • 触发方式:AOF 持久化是通过将所有写命令追加到日志文件来进行的,每个写命令都会被记录下来,AOF 文件记录的是一个操作的执行历史。
  • 存储方式:AOF 会将每个写操作按顺序追加到文件中,生成一个 .aof 文件(例如 appendonly.aof)。
  • 性能:AOF 会比 RDB 更加消耗性能,因为每次写操作都要追加到 AOF 文件,尤其是在配置为“每次写操作都同步”时,性能开销会更大。
  • 恢复速度:AOF 恢复速度比 RDB 慢,因为它需要重新执行每个写操作,尤其是对于大量数据的情况。
  • 数据丢失:AOF 提供了更高的数据持久化保证,理论上能保证即使 Redis 异常关闭,也不会丢失数据,除非是文件损坏等特殊情况。
AOF 的同步策略:

AOF 持久化提供三种不同的同步策略,控制数据追加到磁盘的方式:

  1. 每次写操作后同步(appendfsync always:每次写操作都会立即同步到磁盘,确保最强的数据安全性,但性能开销较大。
  2. 每秒同步(appendfsync everysec:每秒将 AOF 文件同步到磁盘一次,通常是性能和数据安全的平衡点,这是 Redis 默认的策略。
  3. 从不同步(appendfsync no:不主动进行同步,由操作系统决定何时将数据写入磁盘,性能最好,但存在数据丢失的风险。

3. 混合持久化(RDB + AOF)

Redis 4.0 以后引入了混合持久化模式,在该模式下,Redis 将同时使用 RDB 和 AOF 进行持久化操作。

特点:
  • RDB 快照 + AOF 日志:混合持久化模式结合了 RDB 和 AOF 的优点。Redis 会定期创建 RDB 快照,同时使用 AOF 记录写操作。AOF 文件只记录变更部分,减少了 AOF 文件的大小。
  • 性能和恢复速度的平衡:混合持久化模式能在较短的时间内恢复数据,且减少了 AOF 文件的大小和 I/O 操作。
作用:
  • 当 Redis 启动时,如果同时启用了 RDB 和 AOF 持久化,Redis 会优先使用 RDB 快照来恢复数据,如果 RDB 快照不可用,才会使用 AOF 文件。
  • 混合持久化能够避免在 AOF 写入的同时,造成过大的 I/O 压力。
启用方式:

混合持久化默认启用,只需要在 redis.conf 文件中设置 aof-use-rdb-preambleyes 即可。

总结:

  • RDB:通过快照方式持久化数据,性能较高,但可能丢失最近几次操作的数据。
  • AOF:通过记录每个写操作的日志持久化数据,提供更强的数据持久性,但性能开销较大。
  • 混合持久化(RDB + AOF):结合了 RDB 和 AOF 的优点,提升了数据恢复速度并减少了 AOF 文件的大小。

http://www.ppmy.cn/devtools/137564.html

相关文章

设计模式之 备忘录模式

备忘录模式是一种行为型设计模式,它允许你在不暴露对象实现细节的情况下,捕获和保存对象的内部状态。之后,可以通过保存的状态将对象恢复到原先的状态。备忘录模式的核心思想是“在不暴露对象的内部实现的情况下,保存对象的状态&a…

前端自动化运营:提升效率与体验的实践指南

在现代的前端开发与运营中,业务需求的快速变化与用户体验的高标准要求正变得越来越普遍。如何在有限的时间内快速迭代、精准上线、实时响应用户反馈?答案是:前端自动化运营。 本文将从概念出发,结合实际场景,深入探讨前…

OpenOCD之J-Link下载

NOTE:此篇文章由笔者的 VSCode编辑GCC for ARM交叉编译工具链Makefile构建OpenOCD调试(基于STM32的标准库)派生而来。 1.下载USB Dirver Tool.exe,选择J-Link dirver,替换成WinUSB驱动。(⭐USB Dirver Tool…

设计模式-创建型-单例模式

1.概念 该设计模式保证全局只有一个实例对象可以使用,并且自动实例化,向外部提供一个使用接口。 2.作用 保证某些对象在项目中只有一份。 3.应用场景 比如: 全局的计数器——web页面文章阅读计数 全局的资源共享——用户登录后各个页面之…

设计模式学习[9]---模板方法模式

文章目录 前言1.原理阐述1.1 C模板说明1.2 设计模式模板 2.举例3.和原型模式的区别 总结 前言 大型的C项目,都会用到很多模板,C中关于模板的书也不少,那么在设计模式中的模板模式和C的模板又有什么区别呢?模板和上篇的原型又有哪…

Python后端flask框架接收zip压缩包方法

一、用base64编码发送,以及接收 import base64 import io import zipfile from flask import request, jsonifydef unzip_and_find_png(zip_data):# 使用 BytesIO 在内存中处理 zip 数据with zipfile.ZipFile(io.BytesIO(zip_data), r) as zip_ref:extracted_paths…

EasyAnimate:基于Transformer架构的高性能长视频生成方法

这里主要是对EasyAnimate的论文阅读记录,感兴趣的话可以参考一下,如果想要直接阅读原英文论文的话地址在这里,如下所示: 摘要 本文介绍了EasyAnimate,一种利用Transformer架构实现高性能视频生成的高级方法。我们将原…

centos 服务器 docker 使用代理

宿主机使用代理 在宿主机的全局配置文件中添加代理信息 vim /etc/profile export http_proxyhttp://127.0.0.1:7897 export https_proxyhttp://127.0.0.1:7897 export no_proxy"localhost,127.0.0.1,::1,172.171.0.0" docker 命令使用代理 例如我想在使用使用 do…