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

推荐订阅源

cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
Hacker News - Newest:
Hacker News - Newest: "LLM"
S
Security Affairs
PCI Perspectives
PCI Perspectives
Google Online Security Blog
Google Online Security Blog
W
WeLiveSecurity
www.infosecurity-magazine.com
www.infosecurity-magazine.com
Recent Commits to openclaw:main
Recent Commits to openclaw:main
P
Privacy & Cybersecurity Law Blog
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
S
Security @ Cisco Blogs
Security Archives - TechRepublic
Security Archives - TechRepublic
Cyberwarzone
Cyberwarzone
L
Lohrmann on Cybersecurity
TaoSecurity Blog
TaoSecurity Blog
V
Visual Studio Blog
博客园 - 聂微东
Scott Helme
Scott Helme
博客园 - 【当耐特】
K
Kaspersky official blog
Security Latest
Security Latest
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
MyScale Blog
MyScale Blog
Schneier on Security
Schneier on Security
WordPress大学
WordPress大学
博客园 - 叶小钗
C
Check Point Blog
V2EX - 技术
V2EX - 技术
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
博客园 - Franky
T
Tor Project blog
Apple Machine Learning Research
Apple Machine Learning Research
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
腾讯CDC
雷峰网
雷峰网
博客园_首页
美团技术团队
Y
Y Combinator Blog
C
CERT Recently Published Vulnerability Notes
AWS News Blog
AWS News Blog
月光博客
月光博客
N
Netflix TechBlog - Medium
Last Week in AI
Last Week in AI
Recent Announcements
Recent Announcements
Google DeepMind News
Google DeepMind News
Help Net Security
Help Net Security
P
Proofpoint News Feed
MongoDB | Blog
MongoDB | Blog
C
Cybersecurity and Infrastructure Security Agency CISA

博客园_首页

Linux实操--组管理、权限管理和定时任务 Java + EasyExcel 实现单个接口导出多个Excel Mem0 源码解析系列(二):提示词工程的深度剖析 Openclaw TaskFlow究竟是什么?和普通Skill技能有什么区别 博文阅读密码验证 - 博客园 嘉立创开源:应该是全网MicroPython教程最多的开发板 Hermes Agent 集成实践:从协议到生产 2026年AI编程工具横评:Cursor、Codex、Claude Code、Zed、Windsurf Java程序员必看的RAG入门教程 2026 AI效率神器:Superpowers + Claude Code 保姆级教程 本地大模型部署全攻略:从 0 到 1 玩转 Ollama 【从0到1构建一个ClaudeAgent】内存管理-上下文压缩 .NET 高级开发 | 设计、实现一个事件总线框架 电子小白入门之NE555 3. WorkBuddy:隐藏玩法,一键召唤专家,让 AI 以"专家身份"给你干活 和AI一起搞事情#3:Claude Teammate 游戏开发翻车实录 【OpenClaw】通过 Nanobot 源码学习架构---(7)Memory C# .NET 周刊|2026年3月3期 我在 Debian 11 上把 K8s 单机搭起来了,过程没你想的那么顺(/opt 目录版) 深度学习进阶(七)Data-efficient Image Transformer CLI+Skill搭建浏览器AI自动化框架,告别一切重复枯燥任务 告别Token账单无底洞:OpenClaw本地部署,重塑企业数据主权的唯一解 FastAPI+Vue:文件分片上传+秒传+断点续传,这坑我帮你踩平了! SBTI 爆火后,我做了个程序员版的 CBTI。。已开源 + 附开发过程 多模态检索开始进入工程期:用 Sentence Transformers 搭建可落地的 Multimodal RAG 100多行代码实现一个最简单的Agent(用ReAct) Claude Code 通关手册(八):推荐 5 个 Hooks,代码质量提升 3 倍 老板:“有人截图了!”。安全部门:“收到,马上查暗水印!” - why技术 技术之外,皆是人间 C#/.NET/.NET Core技术前沿周刊 | 第 69 期(2026年4.01-4.12) Snack JSONPath 项目架构分析 Claude Code Buddy 小析:一个非核心功能,如何体现产品的细节完成度 AI新时代下的图床管理方案-Cloudflare图床+MCP+Skills方案指南 化繁为简:顺丰速运App如何通过 HarmonyOS SDK实现专业级空间测量 从零实现富文本编辑器#13-React非编辑节点的内容渲染 AI开发-python-langchain框架(3-23-OpenAI Functions风格Tool Calling智能助手) .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 PbootCMS 网站内容数量多导致访问慢?这些实用优化方案帮你提速! - 家兴网络技术工作室 上下文工程是什么?过时了么?一文讲明白! - 一枫说码 网站漏洞怎么发现并修复?一篇实用指南(附完整流程) - 家兴网络技术工作室 开了 TUN 模式还是直连?90% 的人都踩过这个坑 Github日报|2026年04月12日 - AI一族 AScript扩展多种脚本语言 - rockey627 AI 学习笔记:Agent 的记忆机制 你能被装进一个文件里吗?——7 万人把同事"蒸馏"成了 AI - 我没有三颗心脏 Claude Code 通关手册(七):给 AI 装上技能包——Skills 完全指南 - 暮色之狐 在浏览器中快速编辑代码:VSCode Web 集成实践 - Newbe36524 蒸馏自己 skill?基于 Deepseek 的蒸馏器,丐版蒸馏方式,简单便捷 - To_Carpe_Diem Spring AI Aliababa和AgentScope,哪个更好? - 苏三说技术 Etsy 把 1000 个 MySQL 分片迁进 Vitess:425TB 数据背后的真正问题不是性能,而是运维规模 MicroPython LVGL基础知识和概念:底层渲染与性能优化 - FreakStudio 数据库草图算法 Python 潮流周刊#146:CPython 引入 Rust 的进展 - 豌豆花下猫 最小生成树 - mofei1116 红日靶场七:从外网入口、容器逃逸到 AD 接管的完整利用链复盘 - YouDiscovered1t 分享四款开源且实用的 Kafka 管理工具 - 追逐时光者 vLLM 权重加载机制全解析:从挑战到理想架构 LCT 学习笔记 - ACehomoxue Avalonia UI 12.0.0 正式发布:架构演进和性能飞跃 - 张善友 当 AI Agent 把调用链拉长,延迟开始成为一门生意 conhost.exe 无法显示 U+2717 - 145a 太秀了,我把自己蒸馏成了 Skill!已开源 - 程序员鱼皮 ASP.NET Core 内存缓存实战:一篇搞懂该怎么配、怎么避坑 基于 Ghostty 带有分割标签页和为 Claude 编程设计的通知终端 - BugShare AI 焊死入口:教育的“操作系统级”重塑 - 郝hai 初级Java开发工程师使用sql脚本编写代码的过程是简单而且不糊涂 - CoderOilStation Claude Code通关手册(六):MCP协议完全指南 - 暮色之狐 边框灯光环绕动画特效实现指南 - Newbe36524 开源:子木蒸馏版的 SEO 审计工具 seo-audit-skill v1.0 我所理解的Python元模型 【从0到1构建一个ClaudeAgent】规划与协调-TodoWrite - 程序员Seven Claude 和 Codex 在审计 Skill 上性能差异探究 - ACai_sec AScript如何实现中文脚本引擎 - rockey627 【渗透测试】HTB Season10 Garfield 全过程wp - dynasty_chenzi Android 开发者为什么必须掌握 AI 能力?端侧视角下的技术变革 树状数组正确性证明 - AC-wyr 你的 AI 焦虑,可能比 AI 本身更危险——ATM 机没有消灭银行柜员,但恐慌消灭了你的判断力 - 我没有三颗心脏 一个拉胯的分库分表方案有多绝望?整个部门都在救火! - 冰河团队 动态规划入门必学之走方格问题 - Ofnoname PostgREST 与 PostgreSQL 角色权限配置全解析(生产级实践) - SheepDog1998 使用 UEFI 图形输出协议 GOP 在屏幕上显示图像的方法 - 阿源- Claude Code通关手册(五):组建你的AI专家团队,子代理系统 - 暮色之狐 一个程序员到架构师的催婚路之感悟(整整10年后的催婚相亲感悟) - MisterLip 用 Agent Skill 自动生成工作周报 - 赵康
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标题