Redis数据的持久化是如何做的?(面试版)

在Redis中提供了两种数据持久化的方式:RDB、AOF

RDB快照

RDB是什么?

RDB全称Redis Database Backup file(Redis快照),也被叫做Redis数据快照。简单来说就是创建快照来获取内存中某个时间点上的副本。当Redis实例故障重启后,从磁盘读取快照文件,恢复数据。

如何生成RDB快照

在Redis客户端执行命令,人工主动备份方式,以下两个命令都可以生成RDB文件:

  • save命令:使用主进程来生成RDB文件,如果文件比较大,会阻塞其他线程的命令
  • bgsave:利用fork操作得到子进程,由子进程来执行RDB生成,不会阻塞主进程,默认使用bgsave

Redis内部有自动触发RDB的机制(由子进程来执行),可以在redis.conf文件中配置在x秒内如果至少有y个key被修改就会执行bgsave命令,进行持久化操作,格式如下:

RDB的执行原理

fork就相当于拷贝

AOF追加文件

AOF追加文件是什么?

AOF全称为Append Only File(追加文件),Redis处理的每一个写命令都会记录在AOF文件,可以看做是命令日志文件,如下图:

实现

AOF默认是关闭的,需要修改redis.conf配置文件来开启AOF:

AOF的命令记录的频率也可以通过redis.conf文件来配置:

  • 在项目中一般使用everysec

缺点

因为是记录命令,AOF文件会比RDB文件大的多。而且AOF会记录对同一个key的多次写操作,但只有最后一次写操作才有意义。

解决:通过执行bgrewriteaof命令,可以让AOF文件执行重写功能,用最少的命令达到相同效果,如下图:

Redis也会在触发阈值时自动去重写AOF文件。阈值也可以在redis.conf中配置:

RDB与AOF的对比

相关推荐
hnlucky5 分钟前
redis 数据类型新手练习系列——Hash类型
数据库·redis·学习·哈希算法
LucianaiB1 小时前
【金仓数据库征文】_AI 赋能数据库运维:金仓KES的智能化未来
运维·数据库·人工智能·金仓数据库 2025 征文·数据库平替用金仓
时序数据说1 小时前
时序数据库IoTDB在航空航天领域的解决方案
大数据·数据库·时序数据库·iotdb
.生产的驴1 小时前
SpringBoot 封装统一API返回格式对象 标准化开发 请求封装 统一格式处理
java·数据库·spring boot·后端·spring·eclipse·maven
Pasregret1 小时前
多级缓存架构深度解析:从设计原理到生产实践
缓存·架构
AnsenZhu2 小时前
2025年Redis分片存储性能优化指南
数据库·redis·性能优化·分片
oydcm2 小时前
MySQL数据库概述
数据库·mysql
oioihoii2 小时前
C++23中if consteval / if not consteval (P1938R3) 详解
java·数据库·c++23
带娃的IT创业者2 小时前
《AI大模型趣味实战》基于RAG向量数据库的知识库AI问答助手设计与实现
数据库·人工智能
李菠菜3 小时前
非SpringBoot环境下Jedis集群操作Redis实战指南
java·redis