0

0

Java面试——Redis持久化RDB与AOF对比

幻夢星雲

幻夢星雲

发布时间:2026-01-03 01:11:09

|

892人浏览过

|

来源于php中文网

原创

rdb适合定时备份、从节点初始化同步及恢复速度优先且可容忍分钟级数据丢失的场景,但不适用于订单支付等强一致性业务。

java面试——redis持久化rdb与aof对比

Redis RDB 持久化到底适合什么场景

RDB 是通过 fork 子进程生成 dump.rdb 快照文件,适合做冷备和灾难恢复,但不是实时持久化方案。它天然适合定时备份、集群从节点初始化同步、以及对恢复速度要求高、能容忍几分钟数据丢失的业务。

常见误用是把它当唯一持久化手段部署在订单、支付类系统中——一旦宕机且上次 save 是 15 分钟前,就真丢了 15 分钟数据。

  • save 900 1 表示 900 秒内至少 1 次写入才触发快照,低频写入场景下可能长期不落盘
  • fork 耗时与 Redis 实例内存大小强相关:10GB 内存实例 fork 可能卡主进程 100ms+,线上需监控 latest_fork_usec
  • RDB 文件是二进制压缩格式,不能像 AOF 那样用 catgrep 直接查看内容,调试困难

AOF 重写(rewrite)为什么经常导致内存飙升

AOF 重写不是“复制旧日志”,而是由子进程读取当前内存数据,重新生成一条条等效命令写入新 appendonly.aof。这个过程会额外占用一块与当前数据集等大的内存空间(用于构建重写缓冲区 + 子进程页表)。

比如 Redis 使用了 4GB 内存,AOF 重写期间 RSS 很可能冲到 7–8GB,若机器只剩 2GB 空闲内存,就会触发 OOM Killer 杀掉 redis-server。

立即学习Java免费学习笔记(深入)”;

猫目
猫目

AI工具导航与智能应用推荐

下载
  • 重写是否触发取决于 auto-aof-rewrite-percentageauto-aof-rewrite-min-size,建议把后者设为 64mb 以上,避免小文件频繁重写
  • aof-rewrite-incremental-fsync yes 必须开启,否则重写时所有写都积压在 page cache,一次性刷盘易打爆磁盘 I/O
  • 重写期间新写入命令仍会同时写入老 AOF 文件和重写缓冲区,所以 bgrewriteaof 并发执行时要小心缓冲区溢出

RDB + AOF 混合使用时加载顺序和风险点

Redis 4.0+ 支持 aof-use-rdb-preamble yes,此时 AOF 文件开头是一段 RDB 格式数据,后面才是追加的命令。启动时只加载这一个文件,不再先载 RDB 再回放 AOF —— 这是性能关键优化。

但混合模式下最容易踩的坑是:手动替换 AOF 文件后忘记重命名或权限不对,Redis 启动时检测到 appendonly.aof 存在但无法读取,会静默退回到仅加载 RDB(如果有的话),结果就是“以为开了 AOF,其实没生效”。

  • 检查是否真正启用混合模式:启动后执行 CONFIG GET aof-use-rdb-preamble,返回值必须是 yes
  • redis-check-aof --fix 修复损坏 AOF 时,它只会修尾部命令部分,不会碰前面的 RDB preamble,修完记得 cat 前 100 字节确认仍有 Redis RDB magic header(REDIS0009
  • 如果关闭了 RDB 但开启了 AOF,又设置了 aof-use-rdb-preamble no,那 AOF 文件体积会随时间线性增长,务必配好重写策略

面试常问:AOF everysec 模式为什么最多丢 2 秒数据

不是“每秒刷一次盘”就等于“最多丢 1 秒”,而是因为 write(2) 和 fsync(2) 是分离的:appendfsync everysec 表示 Redis 主线程每秒调用一次 write 把日志写入内核 buffer,后台线程再负责 fsync 刷盘。

但如果主线程某次 write 完还没等到后台线程 fsync,实例就崩溃了,这部分刚 write 进 buffer 但未 fsync 的数据就丢了。而两次 fsync 最大间隔接近 2 秒(例如上一次在 00:00:00.999,下一次在 00:00:02.001)。

  • 极端情况下,Linux kernel 的 dirty_ratio 设置过高(如 40%),会导致 write buffer 长期不刷,实际丢失可能远超 2 秒
  • appendfsync always 看似安全,但每次写都 fsync,QPS 跌 5–10 倍,SSD 寿命也会明显下降
  • 生产环境推荐 everysec + 配合高可靠硬件(UPS、RAID 电池保护写缓存),而不是盲目切 always
# 示例:如何验证当前 AOF 是否启用了 RDB preamble
$ strings /var/lib/redis/appendonly.aof | head -c 20
REDIS0009*1\r\n$8\r\nselect\r\n$1\r\n0\r\n

RDB 和 AOF 不是二选一的选择题,而是数据可靠性、恢复速度、运维成本之间的权衡。真正容易被忽略的是:AOF 重写时的内存放大、混合模式下文件损坏的静默降级、以及 everysec 在内核 buffer 满时的行为漂移。这些细节往往比背对比表格更能暴露真实经验。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

723

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

723

2023.08.10

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1002

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

665

2023.11.14

mongodb和redis哪个读取速度快
mongodb和redis哪个读取速度快

redis 的读取速度比 mongodb 更快。原因包括:1. redis 使用简单的键值存储,而 mongodb 存储 json 格式的数据,需要解析和反序列化。2. redis 使用哈希表快速查找数据,而 mongodb 使用 b-tree 索引。因此,redis 在需要高性能读取操作的应用程序中是一个更好的选择。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

500

2024.04.02

redis怎么做缓存服务器
redis怎么做缓存服务器

redis 作为缓存服务器的答案:redis 是一款开源、高性能、分布式的键值存储,可作为缓存服务器使用。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

410

2024.04.07

redis怎么解决数据一致性
redis怎么解决数据一致性

redis 提供了两种一致性模型,以维护副本数据一致性:强一致性 (sync) 确保写操作仅在复制到所有从节点后才完成;最终一致性 (async) 则在主节点上写操作后认为已完成,牺牲一致性换取性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

407

2024.04.07

mysql和redis怎么保证双写一致性
mysql和redis怎么保证双写一致性

确保 mysql 和 redis 双写一致性的技术包括:1、事务性更新:同时更新 mysql 和 redis,保证一致性;2、主从复制:mysql 主服务器更改同步到 redis 从服务器;3、基于事件的更新:mysql 记录更改并发送到 redis等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

475

2024.04.07

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

48

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10万人学习

Git 教程
Git 教程

共21课时 | 4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号