it编程 > 数据库 > Redis

Redis的持久化之RDB和AOF机制详解

34人参与 2025-06-21 Redis

概述

redis 提供 rdb 和 aof 两种持久化机制,它们在数据安全性、性能、恢复速度等方面有显著差异。

为什么要进行持久化?如果是大数据量的恢复,会有下述的影响

rdb(redis database)

核心原理

rdb持久化是把当前进程数据生成快照保存到磁盘上的过程,由于是某一时刻的快照,那么快照中的值要早于或者等于内存中的值

rdb文件默认为当前工作目录下的dump.rdb,可以根据配置文件中的dbfilename和dir设置rdb的文件名和文件位置

触发方式

有下述两种触发方式

手动触发

fork()是由操作系统提供的函数,作用是创建当前进程的一个副本作为子进程

fork一个子进程,子进程会把数据集先写入临时文件,写入成功之后,再替换之前的rdb文件,用二进制压缩存储,这样可以保证rdb文件始终存储的是完整的持久化内容

自动触发

自动触发:以下4种情况时会自动触发

redis.conf中配置save m n,即在m秒内有n次修改时,自动触发bgsave生成rdb文件;

save <seconds> <changes>

表示在seconds秒内,至少有changes次变化,就会自动触发gbsave命令

aof(append-only file)

针对rdb不适合实时持久化的问题,redis提供了aof持久化方式来解决.

核心原理

aof日志采用写后日志,即先写内存,后写日志

配置方式

通过配置redis.conf文件开启aof持久化

# appendonly参数开启aof持久化
appendonly no

# aof持久化的文件名,默认是appendonly.aof
appendfilename "appendonly.aof"

# aof文件的保存位置和rdb文件的位置相同,都是通过dir参数设置的
dir ./

# 同步策略
# appendfsync always
appendfsync everysec
# appendfsync no

# aof重写期间是否同步
no-appendfsync-on-rewrite no

# 重写触发配置
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb

# 加载aof出错如何处理
aof-load-truncated yes

# 文件重写策略
aof-rewrite-incremental-fsync yes

aof实现步骤

aof需要记录redis的每个写命令,步骤为:

不是直接写入文件,避免每次有命令都直接写入硬盘,减少硬盘io次数

文件写入(write),文件同步(sync):何时把aof_buf缓冲区的内容写入保存在aof文件中,redis提供了多种策略,appendfsync选项的默认配置为everysec,即每秒执行一次同步

aof的同步策略是涉及到操作系统的write函数和fsync函数的

aof重写

基本概念

aof会记录每个写命令到aof文件,随着时间越来越长,aof文件会变得越来越大。

为了解决aof文件体积膨胀的问题,redis提供aof文件重写机制来对aof文件进行“瘦身”。

aof重写的目的就是减小aof文件的体积

redis通过创建一个新的aof文件来替换现有的aof,新旧两个aof文件保存的数据相同,但新aof文件没有了冗余命令

触发方式

文件重写可分为手动触发和自动触发

重写过程

aof重写过程是由后台进程bgrewriteaof来完成的。

重写过程总结为:“一个拷贝,两处日志”。在fork出子进程时的拷贝,以及在重写时,如果有新数据写入,主线程就会将命令记录到两个aof日志内存缓冲区中

重写过程中主线程有哪些地方会被阻塞?

fork子进程时,需要拷贝虚拟页表,会对主线程阻塞。

主进程有bigkey写入时,操作系统会创建页面的副本,并拷贝原有的数据,会对主线程阻塞。

子进程重写日志完成后,主进程追加aof重写缓冲区时会对主线程阻塞

为什么不复用原aof日志

子进程写同一个文件会产生竞争问题,影响父进程的性能。

如果aof重写过程中失败了,相当于污染了原本的aof文件,无法做恢复数据使用

rdb vs aof

维度rdbaof
数据安全性低(依赖快照周期)高(可配置秒级同步)
性能影响低(后台异步)中高(同步写盘/重放命令)
恢复速度快(直接加载二进制)慢(逐条执行命令)
文件体积小(压缩存储)大(需重写优化)
适用场景容灾备份/快速恢复金融级数据安全要求

redis 4.0 中提出了一个混合使用 aof 日志和内存快照的方法。简单来说,内存快照以一定的频率执行,在两次快照之间,使用 aof 日志记录这期间的所有命令操作

aof 日志也只用记录两次快照间的操作,也就是说,不需要记录所有操作了,因此,就不会出现文件过大的情况了,也可以避免重写开销

这个方法既能享受到 rdb 文件快速恢复的好处,又能享受到 aof 只记录操作命令的简单优势, 实际环境中用的很

如何保证数据一致性

rdb中的核心思路是copy-on-write,来保证在进行快照操作的这段时间,需要压缩写入磁盘上的数据在内存中不会发生变化。

例如:

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

您想发表意见!!点此发布评论

推荐阅读

基于Redis的分布式锁及原子性问题(短视频开发)

06-21

Redis 配置文件使用建议redis.conf 从入门到实战

06-20

Redis分片集群、数据读写规则问题小结

06-20

一文浅析如何在Redis中实现缓存功能

06-22

Redis中对大Key进行处理方式

06-22

Ubuntu 22.04安装配置FTP服务器的详细教程

06-22

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论