Redis数据安全性分析之RDB详解

1.RDB 能干什么?

RDB 可以在指定的时间间隔,备份当前时间点的内存中的全部数据集,并保存到磁盘文件中。通常是 dump.rdb 文件。

在数据恢复时,将瓷片中的快照文件直接读回到内存里。

由于 RDB 存的是全量数据,甚至可以直接用 RDB 来传递数据,例如如果需要从一个 Redis 服务中间数据同步到另一个 Redis 服务(最好是同版本),就可以直接复制最近的 RDB 文件。

2 相关配置

  • save 策略:核心配置
  • dir 文件目录
  • dbfilename 文件名,默认 dump.rdb
  • rdbcompression 是否启用 RDB 压缩,默认 yes。如果不想消耗 CPU 进行压缩,可以设置为 no
  • stop-writes-oin-bgsave-error 默认 yes。如果配置成 no,表示不在乎数据不一致,在快照写入失败时,也能确保 Redis 继续接受新的写入请求。
  • rdbchecksum 默认 yes。在存储快照后,可以让 Redis 使用 CRC64 算法进行数据校验,但是这样做会增加大约 10%的性能消耗,如果希望获得最大的性能提升,可以关闭此功能。

3.触发 RDB 备份的时机

1.到达配置文件中默认的快照配置时间时,会自动触发 RDB 快照

2.手动执行 save 或者 bgsave 指令时,会触发 RDB 快照。其中 save 方法会在备份期间阻塞主线程。bgsave 则不会阻塞主线程,但是它会 fork 一个子线程进行持久化,这个过程中会将数据复制一份,因此会占用更多内存和 CPU。

3.主从复制时会触发 RDB 备份。

4.RDB 持久化的优缺点

4.1.优点

1.RDB 文件非常紧凑,非常适合定期备份数据。

2.RDB 快照非常适合灾难恢复。

3.RDB 备份时性能非常快,对主线程的性能几乎没有影响。RDB 备份时,主线程只需要启动一个负责数据备份的子线程即可,所有的备份工作都有子线程完成,这对主线程的 IO 性能几乎没有影响。

4.与 AOF 相比,RDB 在进行大数据量重启时会快很多。

4.2.缺点

  • RDB 不能对数据进行实时备份,所以总会有数据丢失的可能。
  • RDB 需要 fork 子线程的数据写入情况,在 fork 过程中,需要将内存中的数据克隆一份,如果数据量太大,或者 CPU 性能不是很好,RDB 方式就容易造成 Redis 服务短暂停用。相比之下 AOF 也需要进行持久化,但是频率低并且可以调整日志重写的频率。
相关推荐
dfdfadffa几秒前
如何创建仅在首次订阅时执行一次计算的 RxJS 懒加载 Observable
jvm·数据库·python
Irene19912 分钟前
Oracle 中:为什么 from 子查询后面需要一个别名
数据库·oracle
m0_624578594 分钟前
SQL分组后如何计算移动平均值_利用窗口函数AVG配合ROWS
jvm·数据库·python
2401_8242226911 分钟前
如何修复待办事项列表无法添加任务的 JavaScript 错误
jvm·数据库·python
地球资源数据云15 分钟前
1900-2023年中国物种分布点位矢量数据集
大数据·数据结构·数据库·数据仓库·人工智能
sitellla39 分钟前
MySQL 入门:最流行的开源关系型数据库介绍
数据库·mysql·其他·开源
IT界的老黄牛41 分钟前
停电后 Redis 集群两节点起不来:fix 完还报 Bad file format?多部分 AOF 修复的正确姿势
运维·redis·缓存
精益数智工坊41 分钟前
拆解制造业仓库物料管理流程:如何通过标准化仓库物料管理流程解决账实不符难题
大数据·前端·数据库·人工智能·精益工程
nbwenren1 小时前
办公AI实测:Gemini3、GPT-4o、Claude3.5谁更强?
服务器·数据库·php
2401_824222691 小时前
如何卸载并重装Oracle Grid_Deinstall脚本与ASM磁盘清理
jvm·数据库·python