Redis

关注公众号 jb51net

关闭
首页 > 数据库 > Redis > Redis持久化之RDB和AOF机制

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

作者:?abc!

这篇文章主要介绍了Redis的持久化之RDB和AOF机制,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

概述

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,来保证在进行快照操作的这段时间,需要压缩写入磁盘上的数据在内存中不会发生变化。

例如:

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文