惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Forbes - Security
Forbes - Security
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
F
Fortinet All Blogs
B
Blog
T
The Blog of Author Tim Ferriss
Engineering at Meta
Engineering at Meta
GbyAI
GbyAI
Y
Y Combinator Blog
Microsoft Azure Blog
Microsoft Azure Blog
L
LangChain Blog
Recent Announcements
Recent Announcements
U
Unit 42
Martin Fowler
Martin Fowler
M
MIT News - Artificial intelligence
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
The Register - Security
The Register - Security
Recorded Future
Recorded Future
C
Check Point Blog
V
V2EX
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Hugging Face - Blog
Hugging Face - Blog
WordPress大学
WordPress大学
Google DeepMind News
Google DeepMind News
酷 壳 – CoolShell
酷 壳 – CoolShell
F
Full Disclosure
小众软件
小众软件
A
About on SuperTechFans
云风的 BLOG
云风的 BLOG
宝玉的分享
宝玉的分享
Last Week in AI
Last Week in AI
有赞技术团队
有赞技术团队
MongoDB | Blog
MongoDB | Blog
爱范儿
爱范儿
P
Proofpoint News Feed
罗磊的独立博客
量子位
D
Docker
博客园_首页
D
DataBreaches.Net
Project Zero
Project Zero
博客园 - 司徒正美
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
博客园 - Franky
Security Latest
Security Latest
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
N
Netflix TechBlog - Medium
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
博客园 - 三生石上(FineUI控件)
H
Hackread – Cybersecurity News, Data Breaches, AI and More
大猫的无限游戏
大猫的无限游戏

博客园_首页

Plist 二进制格式 Milvus 和 PGVector,哪个更好? OpenClaw 已过时?在 VS Code 中运行 Hermes Agent! 第30篇文章:一个大三计科生的自白 Manim如何在数学公式中完美显示中文? Docker 部署 RocketMQ 5 并发编程核心概念辨析 C#事务处理最佳实践:别再让“主表存了、明细丢了”的破事发生 CLI 是什么?为什么大厂突然集体卷命令行? 【从0到1构建一个ClaudeAgent】协作-自主Agent UIImageView 设置图片不生效的原因排查 最小二乘问题详解20:无先验约束下的增量式SFM自由网平差 痞子衡嵌入式:大话双核i.MXRT1180之XIP应用里借助MU实现可靠Flash IAP的方法 AI Chat 封装, SemanticKerne.AiProvider.Unified 已发布 Windows下右键编辑js文件无法打开记事本——在注册表中使用环境变量 在后台服务中使用 Scoped 服务,为什么总是报错? H200 安装驱动并使用sglang启动模型 wireshark 抓包Trap上报告警内容 我用 AI 辅助开发了一系列小工具(2):图片压缩工具 [A Primer On MC and CC] 2.1 Memory Consistency 1 - 指令重排序和 SC 模型 Oracle数据库SCN推进技术详解与实践指南 玩转控件:封装个带图片的Label控件 Claude Code 4.7 真正该升级的不是模型,而是你的工作流 前端小白一句话,AI 帮我做了个颜值拉满的桌面媒体播放器。当代码不再是门槛,一句话编程就是现实。 5. WorkBuddy: 小龙虾的灵魂三件套,让你的小龙虾不只是工具 SQLite 分片方案实战:三种分片策略的深度对比 告别简陋 UI!一款基于 Fluent Design 和基于 WinUI 的开源免费、现代化的 Avalonia UI 控件库 关于二进制排列组合枚举的总结 AI开发-python-LangGraph框架(3-27-LangGraph从零实现大模型智能决策工作流) ElasticSearch主分片和副本分片概念详解 【002】HTTPS 粗解:证书、TLS 握手与对后端配置的影响 Hermes Agent 一周暴涨五万 Star,但我劝你别急着追 明明连接的是Redis的DB0,为什么能查到DB3的数据? 【从0到1构建一个ClaudeAgent】协作-Agent团队 熟悉电子元器件之后,电子小白下一步该怎么走? MAF快速入门(23)通过C#类定义Skills .NET 高级开发 | 手写一个对象映射框架 FastAPI数据库ORM怎么选?我肝了三个Demo后,终于不再纠结了 mysqldump 参数拾遗:在遗忘与铭记之间 C# .NET 周刊|2026年3月5期 Claude code入门 - 陈彦斌 一文学习入门 ThingsBoard 开源物联网平台 GitHub 热门项目 | 2026年04月16日 如何为GIT设置全局勾子,为每次提交追加信息 Number.isFinite和isFinite与isNaN()和Number.isNaN的区别 PortSwigger SQL注入LAB2 推荐一个测试人必备的Skills,从功能到性能全搞定(附详细实操和安装下载方式) 筑基期:掌握Odoo基础核心知识点02(Odoo XML 开发方式详解) GLM模型这么火,咱们用vllm也咧一个呗! 深入理解 AbortController:从底层原理到跨语言设计哲学 字符串学习笔记 多租户系统框架的基础模块设计和分析设计 Apache SeaTunnel Zeta 为什么能做到“又快又稳”? AI开发-python-LangGraph框架(3-26-LangGraph基本概念及第一个简单样例) Vue 3 组件通信,别只会用 Props 和 Emits 了,这几个狠活儿你得看看 ElasticSearch7.X版本配置密码 用Manim实现动态交点计算--从一个动点问题说起 团结引擎+Addressable+Instant Game打包抖音小游戏 function call 实战:让 LLM 自动判断 pod 异常、调用日志工具并完成故障分析 bubseek —— 让 Agent 的足迹,变成团队的洞察 通过 C# 读取并导出 PDF 书签 如何用 GitHub Actions 实现 Steam 自动化发布 【从0到1构建一个ClaudeAgent】并发-后台任务 .NET 高级开发 | 定制 ASP.NET Core 框架 电子小白:什么是运算放大器(运放) zero2Agent:面向大厂面试的 Agent 工程教程,从概念到生产的完整学习路线 堆上的ORW HC32F460 USB CDC通信异常:非对齐访问异常排查 20260413-Hyperbridge 攻击事件:发生在默克尔山上的验证绕过 那些喊着AI 要淘汰你的人,正在靠你的焦虑赚大钱! 深度学习进阶(八)Swin Transformer 最小二乘问题详解19:带先验约束的增量式SFM优化与实现 SnapTranslate 3.0 正式发布:全局划词翻译 + 完整英语学习闭环,一站式搞定查词、记词、复习 工作的意义、工作的困难认知再思考 .NET + AI 进阶实战:基于类的技能开发 - 打造可治理的 Agent 能力模块 【从0到1构建一个ClaudeAgent】规划与协调-技能 上周热点回顾(4.6-4.12) 电子小白的工具三件套:面包板、杜邦线、万能板 单表五亿数据的查询优化 | Mysql、StarRocks 2. WorkBuddy:从“我是谁”到“帮我干活” C# 如何减少代码运行时间:7 个实战技巧 基于HelixToolkit.SharpDX 渲染3D模型 - 笺上知微 从零开始的双臂具身VLA起源及现阶段发展综述 - SkyXZ 记对 xonsh shell 的使用, 脚本编写, 迁移及调优 - pluvium27 受够了Vibe Coding的失控?换个起点,让AI事半功倍 从开始配置漏洞环境到漏洞复现流程 - 難しい 关于10年工作经验的程序员对OpenClaw的实战经验分享以及看法 - 虚无境 Any metadata 的内存布局 C# .NET 周刊|2026年3月2期 - InCerry 我帮你测过了,测试圈排名第二的 Skill 依然很牛逼 Skill Discovery | 无监督技能发现的经典工作总结 - MoonOut 上下文工程是什么?过时了么?一文讲明白! - 一枫说码 开了 TUN 模式还是直连?90% 的人都踩过这个坑 AScript扩展多种脚本语言 - rockey627 AI 学习笔记:Agent 的记忆机制 你能被装进一个文件里吗?——7 万人把同事"蒸馏"成了 AI - 我没有三颗心脏 Claude Code 通关手册(七):给 AI 装上技能包——Skills 完全指南 - 暮色之狐 在浏览器中快速编辑代码:VSCode Web 集成实践 - Newbe36524 蒸馏自己 skill?基于 Deepseek 的蒸馏器,丐版蒸馏方式,简单便捷 - To_Carpe_Diem Spring AI Aliababa和AgentScope,哪个更好? - 苏三说技术
Redis-持久化之RDB
NE_STOP · 2026-05-05 · via 博客园_首页

Redis持久化

Redis具有持久化功能,其会按照设置以快照或操作日志的形式将数据持久化到磁盘。

Redis的持久化分为两种:RDB与AOF

持久化基本原理

Redis持久化也称钝化,指将内存中数据库的状态描述信息保存到磁盘

可以通过手动、自动定时、自动条件触发等方式,将内存中数据保存到持久化文件。

当系统重启后,自动加载持久化文件,根据文件中的信息将数据恢复到内存中,这个恢复过程称为激活

这个钝化与激活的过程就是持久化的基本原理。

注意:Redis单机状态下,无论哪种触发方式,都存在数据丢失问题:在未保存数据到内存时发生了宕机,那么从上次保存到宕机期间产生的数据就会丢失。不同的持久化方式,数据的丢失率不同。

RDB是Redis默认持久化方式,但Redis允许RDB与AOF同时开启。此时系统会使用AOF做持久化,即AOF的优先级更高。也就是,同时开启状态下,系统启动时若两种持久化文件同时存在,则优先加载AOF持久化文件。

无标题

RDB持久化

RDB Redis DataBase,指将内存中某一时刻的数据快照全量写入到指定的rdb文件的持久化技术。

RDB默认开启

当Redis启动时会自动读取RDB快照文件,将数据从硬盘载入到内存,以会Redis关机前的数据库状态。

持久化的执行

RDB持久化执行有三种方式:手动save命令、手动bgsave命令、自动条件触发。

  • 手动save命令

无标2题

注意:此命令在执行期间会阻塞Redis进程,直至执行完毕。在Redis阻塞期间,Redis无法执行任何读写操作,无法对外提供服务。

  • 手动bgsave命令

无标3题

bgsave (backgroud save)命令可立即进行一次持久化保存。不同于save命令,bgsave 后台允许save。

bgsave 会使服务器进程生成一个子进程,由这个子进程完成保存,在子进程执行期间不会阻塞Redis进程。

  • 自动条件触发

自动条件触发本质仍是bgsave命令,只不过是通过在品牌配置文件中做相应的设置后,Redis会根据设置辛纳希自动调用bgsave命令执行。

  • 查看持久化时间

执行lastsave命令可以查看最近一次执行持久化的时间,返回的是一个Unix时间戳。

无标4题

RDB优化配置

RDB的相关配置在redis.conf文件的SNAPSHOTTING部分。

save

无标5题

该配置用于设置自动保存触发条件,即save point 保存点。

该触发条件指:规定时间发生了指定次数的写操作。

默认的持久化条件是:save 3600 1 300 100 60 10000.其意思是:

save 3600 1 # 在3600秒内(1小时)发生1次写操作
save 300 100 # 在300秒内(5分钟)发生100次写操作
save 60 10000 # 在60秒内(1分钟)发生10000次写操作

如果不启用RDB持久化,设置save的参数为空串即可:save “”

注意:这个配置虽然以save开头,实际执行的是bgsave命令。

stop-write-on-bgsave-error

默认情况下,RDB快照已启用(至少一个保存点),且最近的bgsave命令失败,Redis将停止接收写入。

这样设置的目的是让用户意识到数据没有正确的保存到磁盘上,否则可能会发生一些灾难。

如果bgsave命令后来正常工作了,Redis自动允许再次写入。

默认配置如下:

stop-write-on-bgsave-error yes

rdbcompression

rdbcompression 的作用是进行持久化时启用LZF压缩字符串对象。

虽然压缩RDB文件会消耗系统资源,但可以大幅降低文件大小,方便保存到磁盘,加速主从集群中从节点的数据同步。

rdbcompression yes

rdbchecksum

RDB文件的CRC64校验和放置在了文件末尾。这使个格式更能抵抗RDB文件的虽坏,但在保存和加载RDB文件时,性能会受到影响。

因此可以设置为no禁用校验和以获得最大性能。这样会告诉加载代码跳过校验检查。

默认yes,开启校验功能。

rdbchecksum yes

sanitize-dump-payload

此配置用于设置:在加载RDB文件或进行持久化时是否开启对zipList、listPack等数据的全面安全检测。

检测可以降低命令处理时系统崩溃的可能。其可选值有三种:

  • no:不检测
  • yes:总是检测
  • clients:只有当客户端连接时才检测。排除了加载RDB文件时和持久化时的检测。

默认值为no,不检测。

dbfilename

指定RDB文件名称,默认为dump.rdb

dbfilename dump.rdb

rdb-del-sync-files

主从复制时,是否自动删除同步的从机上的RDB文件。

默认是no,不删除。

注意:只有从机的RDB和AOF持久化功能都未开启时才生效。

dir

指定RDB和AOF文件的生成目录,默认时Redis安装的根目录。

dir ./

RDB文件结构

RDB持久化文件dump.rdb由五部分构成:

无标6题

SOF

SOF是一个常量,一个字符串REDIS,仅包含这5个字符,长度为5.

用于表示RDB文件的开始,以便在加载RDB文件时可以迅速判断出文件是否是RDB文件。

rdb_version

这是一个整数,长度为4字节,表示RDB文件的版本号。

EOF

EOF是一个常量,占1个字节,用于标识RDB数据的结束,校验和的开始

check_sum

check_sum(校验和)用于判断RDB文件中的内容是否出现数据异常。采用的是CRC校验算法。

CRC校验算法:
	在持久化时,先将SOF、rdb_version及内存数据库里的数据快照这三者的二进制数据拼接起来。
	形成一个二进制数(假设为a),然后将a除以check_sum,得到余数b,再将b拼接到a后面,形成database。
	加载时,先使用check_sum对RDB文件进行数据损坏验证。过程如下:
	将RDB文件中除EOF和check_sum外的数据除以check_sum。只要余数!=0,就说明文件已损坏。当然,如果余数是0,也不能肯定文件没有损坏。
	这种验证算法是数据损坏校验,而不是数据没有损坏的校验。

database

无标7题

database是RDB文件中最重要的数据部分,包含任意多个非空数据库。每个database由三部分组成:

  • SODB:一个常量,占1字节,标识一个数据库的开始
  • db_number:数据库编号
  • key_values_pairs:当前数据库中键值对的数据。每个key_values_pairs由很多个用于描述键值对的数据组成:

无标8题

  • VALUE_TYPE:一个常量。占1个字节,标识键值对中value的类型

  • EXPTRETIME_UNIT:一个常量,占1个字节,标识过期时间的单位是秒还是毫秒

  • time:当前key-value的过期时间。

RDB持久化过程

无9标题

RDB在进行bgsave持久化时,redis-server进程会fork一个子进程,以异步方式完成持久化,期间redis-server进程不会阻塞,会继续接收并处理用户的读写请求。

bgsave子进程的工作原理如下:

​ 子进程会继承父进程的资源,先将内存中全量数据copy到一个RDB临时文件,copy结束后,将该文件rename为dump.rdb,替换掉原来的同名文件。

​ 不过,在持久化过程中,如果redis-server进程接收到了读写请求。系统会将发生数据修改的物理块copy出一个副本,等全量数据copy结束后,再将副本中的数据copy到RDB临时文件。这个副本的生成是由Linux系统的写时复刻技术(copy-on-write)实现的。

写时复刻:子进程会继承父进程的所有资源,其中包括主进程的内存空间。及子进程和父进程共享内存。只要内存被共享,那么该内存就是只读的(写保护的)。而写时复刻是在任何一方需要写入数据到共享内存时都会出现异常。此时内核进程会将需要写入的数据copy出一个副本写入到另外一块非共享内存区域。

无10标题