尚硅谷redis7 33-36 redis持久化之RDB优缺点及数据丢失案例

news2025/6/4 1:08:07

官网说明优点:

  • RDB是Redis数据的一个非常紧凑的单文件时间点表示,RDB文件非常适合备份。例如,您可能希望在最近的24小时内每小时旧档一次RDB文件,并在30天内每天保存一个RDB快照,这使您可以在发生来难时轻松恢复不同版本的数据集。
  • RDB非常适合灾难恢复,它是一个可以传输到远程数据中心或Amazon S3(可能已加密)的压编文件。
  • RDB最大限度地提高了Redis的性能,因为Redis父进程为了持久化而需要做的唯一工作就是派生一个将完成所有其余工作的子进程。父进程永远不会执行磁盘I/O或类似操作。
  • 与AOF相比,RDB允许使用大数据集更快地重启。
  • 在副本上,RDB支持重启和故障转移后的部分重新同步。

总结RDB的优点:

  1. 适合大规模的数据恢复
  2. 按照业务定时备份
  3. 对数据完整性和一致性要求不高
  4. RDB文件在内存中的加载速度要比AOF快得多

官网说明缺点:

  • 如果您需要在Redis停止工作时(例如断电后)将数据丢失的可能性降到最低,那么RDB并不好。您可以配置生成RDB的不同保存点例如,在对数据集至少5分钟和100次写入之后,您可以有多个保存点)。但是,您通常会每五分钟或更长时间创建一次RDB快照,因此,如果Redis由于任何原因在没有正确关闭的情况下停止工作,您应该准备好丢失最新分钟的数据。
  • RDB需要经常fork()以便使用子进程在磁盘上持久化。如果数据集很大,fork()可能会很耗时,并且如果数据集很大并且CPU性能不是很好,可能会导致Redis停止为客户端服务几毫秒甚至一秒钟。AOF也需要fork0但频率较低,您可以调整要重写日志的频率,而不需要对持久性进行任何权衡。

总结RDB的缺点:

  • 在一定间隔时间做一次备份,所以如果redis意外down掉的话,就会丢失从当前至最近一次快照期间的数据,快照之间的数据会丢失
  • 内存数据的全量同步,如果数据量太大会导致I/0严重影响服务器性能
  • RDB依赖于主进程的fork,在更大的数据集中,这可能会导致服务请求的瞬间延迟。fork的时候内存中的数据被克隆了一份,大致2倍的膨胀性,需要考虑

前提:save 5 2   5秒内修改两次即自动触发save

操作1:目前未生成rdb文件

操作2:5秒内有k1 k2两次操作

操作3:发现生成rdb文件

操作4:set k3 

操作5:发现rdb文件的生成时间和操作3相同,并没有生成新的rdb文件

操作6:检查redis数据库,只有k1 k2 k3三个数据。还未写入k4,redis宕机

蓝色框表示宕机后redis重新连接后,只有k1 k2没有k3

34 redis持久化之RDB修复命令简介

dump.rdb文件在写入和迁移的过程中可能会出现文件破损。

首先cd /usr/local/bin  目录中存在redis-check-rdb

对于稍微破损的rdb文件,可以用redis-check-rdb修复

redis-check-rdb /myredis/dumpfiles/dump6379.rdb

35 redis持久化之RDB触发小结和快照禁用

哪些情况会触发RDB快照

  • 配置文件中默认的快照配置
  • 手动save/bgsave命令
  • 执行flushall/flushdb命令也会产生dump.rdb文件,但里面是空的,无意义
  • 执行shutdown且没有设置开启AOF持久化
  • 主从复制时,主节点自动触发

如何禁用快照

动态所有停止RDB保存规则的方法:redis-cli config set save ""【命令级别】

  • 立即生效(不需要重启 Redis)

  • 只影响当前运行实例

  • 重启 Redis 后会失效(恢复为配置文件中的设置)

快照禁用【通过配置文件修改】

  • 永久禁用 RDB 快照,如图去掉save ""的注释

redis持久化之RDB优化参数

配置文件中的SNAPSHOTTING模块可以配置RDB

save <seconds> <changes>

dbfilename

dir

stop-writes-on-bgsave-error

stop-writes-on-bgsave-error 是 Redis 中的一个配置项,用来控制当 RDB 持久化失败时,是否阻止写入操作

默认yes:表示当 Redis 执行 BGSAVE(后台保存 RDB 文件)失败时,将拒绝客户端的写入操作,以避免数据进一步丢失。
如果配置成no,表示你不在乎数据不一致或者有其他的手段发现和控制这种不一致,那么在快照写入失败时,也能确保redis继续接受新的写请求

rdbcompression

默认yes
对于存储到磁盘中的快照,可以设置是否进行压缩存储。如果是的话,redis会采用LZF算法进行缩。
如果你不想消耗CPU来进行压缩的话,可以设置为关闭此功能

rdbchecksum

默认yes
在存储快照后,还可以让redis使用CRC64算法来进行数据校验,但是这样做会增加大约10%的性能消耗,如果希望获取到最大的性能提升,可以关闭此功能

rdb-del-sync-files

当 Redis 没有启用持久化(即 RDB 和 AOF 都禁用)时,Redis 会在复制(replication)完成后自动删除生成的临时 RDB 文件。默认情况下no,此选项是禁用的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2386596.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

计算机网络-WebSocket/DNS/Cookie/Session/Token/Jwt/Nginx

文章目录 WebSocketDNS什么是dns域名解析底层协议 cookie/sessionToken/JWTNginx WebSocket 一种网络通信协议&#xff0c;允许在单个 TCP&#xff08;半双工&#xff09; 连接上进行全双工通信&#xff08;客户端和服务器可同时双向传输数据&#xff09;。 HTTP是基于请求-响…

将网页带格式转化为PDF

# 一、安装插件 SingleFile | 将完整的页面保存到一个 HTML 文件中 – 下载 &#x1f98a; Firefox 扩展&#xff08;zh-CN&#xff09; 打开火狐浏览器&#xff0c;安装上面的插件 # 二、下载html单文件 打开对应的网页&#xff0c;点击插件下载对应的html文件 # 三、打开…

【ArcGIS】ArcGIS AI 助手----复现

github地址 korporalK/Archer-GIS-AI-Assitant&#xff1a;Archer 在 ArcGIS Pro 中将自然语言命令转换为自动化 GIS 工作流。它使用代理框架&#xff08;计划-验证-执行&#xff09;构建并由 LLM 提供支持&#xff0c;可简化空间分析、减少手动工作并使 GIS 更易于访问。Arch…

充电枪IEC62196/EN 62196测试内容

充电枪IEC62196/EN 62196测试内容 一、机械性能测试 插拔力测试 交流充电接口的插入/拔出力需≤100N&#xff0c;直流接口≤140N。若使用助力装置&#xff0c;操作力仍需满足上述要求。 测试方法&#xff1a;通过弹簧秤或专用试验机&#xff08;如Sun-CB设备&#xff09;测…

SAP ERP 系统拆分的七大挑战

在企业变革或管理运营风险时&#xff0c;剥离IT系统能带来显著效益&#xff0c;但SAP ERP系统的复杂性使得这项工作充满挑战。如果管理不当&#xff0c;可能会导致数据不一致、运营中断、合规风险和意外成本。由于SAP ERP系统深度集成于企业核心业务流程中&#xff0c;其拆分工…

AcrelEMS 3.0智慧能源管理平台:构建企业微电网数智化中枢

安科瑞电气顾强 在"双碳"目标驱动下&#xff0c;企业能源管理正从粗放式运营向精细化、智能化转型。AcrelEMS 3.0智慧能源管理平台以微电网为核心载体&#xff0c;通过"感知-分析-决策-控制"的全链路数字化能力&#xff0c;助力工商企业、医疗机构、教育机…

Word转PDF--自动生成目录

1-Word文档中已经包含自动生成的目录&#xff1b; 2-选择“文件”&#xff1b; 3-另存为&#xff0c;PDF&#xff1b; 4-选择“选项”按钮&#xff0c;在弹出的窗口中&#xff0c;勾选“创建书签时使用标题”。

轻量级视觉语言模型 Dolphin:高效精准的文档结构化解析利器

在数字化办公和学术研究日益普及的今天&#xff0c;如何高效、准确地处理各类文档图像成为了一个亟需解决的问题。Dolphin 应运而生&#xff0c;作为一款基于异构锚点提示的多模态文档图像解析模型&#xff0c;它不仅打破了传统手动整理文档的繁琐流程&#xff0c;更以远超主流…

如何安全配置数据库(MySQL/PostgreSQL/MongoDB)

数据库是许多应用程序的核心组成部分&#xff0c;因此保护数据库的安全性至关重要。无论是MySQL、PostgreSQL还是MongoDB&#xff0c;都需要经过适当的安全配置才能防止潜在的安全威胁。本文将介绍如何安全配置这些流行的数据库管理系统&#xff0c;以确保数据的保密性、完整性…

将 Docker 镜像从服务器A迁移到服务器B的方法

在日常工作中&#xff0c;我们有时会需要将服务器 A上的镜像上传至服务器B上&#xff0c;下面给出具体操作方式&#xff0c;以镜像 postgres:15 为例进行讲解。 首先在服务器A上拉取 镜像 postgres:15 &#xff0c;命令如下&#xff1a; docker pull postgres:15下面再将服务…

git merge解冲突后,add、continue提交

git merge解冲突后&#xff0c;add、continue提交 git merge操作冲突后&#xff0c;需要手动解冲突&#xff0c;解完冲突后&#xff0c;需要: git add . 然后&#xff0c;进入一般的正常git代码提交流程。 git合并‘merge’其他分支的个别文件到当前branch_gitbash 合并branc…

运动规划实战案例 | 图解基于状态晶格(State Lattice)的路径规划(附ROS C++/Python仿真)

目录 1 控制采样 vs 状态采样2 State Lattice路径规划2.1 算法流程2.2 Lattice运动基元生成2.3 几何代价函数2.4 运动学约束启发式 3 算法仿真3.1 ROS C仿真3.2 Python仿真 1 控制采样 vs 状态采样 控制采样的技术路线源自经典的运动学建模思想。这种方法将机器人的控制指令空…

Neo4j(二) - 使用Cypher操作Neo4j

文章目录 前言一、Cypher简介二、数据库操作1. 创建数据库2. 查看数据库3. 删除数据库4. 切换数据库 三、节点、关系及属性操作1. 创建节点与关系1.1 语法1.2 示例 2. 查询数据2.1 语法2.2 示例 3. 更新数据3.1 语法3.2 示例 4. 删除节点与关系4.1 语法4.2 示例 5. 合并数据5.1…

09、供应商管理数字化转型:从潜在评估到战略合作的系统化方法

在全球化竞争和供应链日益复杂的商业环境下&#xff0c;供应商管理已成为企业核心竞争力的关键组成部分。优秀的供应商管理体系不仅能确保物料和服务的稳定供应&#xff0c;更能成为企业创新、降本增效的战略资源。本文将系统性地介绍供应商管理的完整框架&#xff0c;从潜在供…

批量转存夸克网盘内容并分享实操教程

批量转存夸克网盘内容并分享 经常使用我AI工具&#xff08;圈友互联AI&#xff09;的应该在每日资源这里看到&#xff0c;会每天自动更新最新资源信息&#xff0c;这些资源是自动从各处爬取出来再批量转存进行分享处理的&#xff01; 今天就和大家分享下&#xff0c;如何对夸克…

“安康杯”安全生产知识竞赛活动流程方案

一、竞赛组织部门&#xff1a;排水公司安全生产办公室 二、竞赛说明&#xff1a; 1、由安全生产办公室组编辑、整理&#xff0c;安全生产领导小组审核。竞赛时由公司领导及各部门负责人对本次知识竞赛进行监督评比&#xff0c;以保证竞赛活动的公平、公正。本次竞赛活动由闫红…

特征分解:线性代数在AI大模型中的核心工具

🧑 博主简介:CSDN博客专家、CSDN平台优质创作者,高级开发工程师,数学专业,10年以上C/C++, C#, Java等多种编程语言开发经验,拥有高级工程师证书;擅长C/C++、C#等开发语言,熟悉Java常用开发技术,能熟练应用常用数据库SQL server,Oracle,mysql,postgresql等进行开发应用…

理解计算机系统_并发编程(10)_线程(七):基于预线程化的并发服务器

前言 以<深入理解计算机系统>(以下称“本书”)内容为基础&#xff0c;对程序的整个过程进行梳理。本书内容对整个计算机系统做了系统性导引,每部分内容都是单独的一门课.学习深度根据自己需要来定 引入 接续理解计算机系统_并发编程(9)_线程(六):读者-写者问题-…

身份认证: JWT和Session是什么?

一、为什么需要临时凭证&#xff1f; 系统面临三个核心约束&#xff1a; 唯一鉴权方式只有&#xff08;账号&#xff0c;密码&#xff09; 服务端不记录请求状态&#xff0c;服务端不知道用户已登录了 避免重复传输敏感信息&#xff0c;不能每次都携带(账号&#xff0c;密码…

机器学习中的多GPU训练模式

文章目录 一、数据并行&#xff08;Data Parallelism&#xff09;二、模型并行&#xff08;Model Parallelism&#xff09;1. 模型并行2. 张量并行&#xff08;Tensor Parallelism&#xff09; 三、流水线并行&#xff08;Pipeline Parallelism&#xff09;四、混合并行&#x…