做网站时的兼容问题/汕头网页搜索排名提升
💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快!
💝💝💝如有需要请大家订阅我的专栏【Redis系列】哟!我会定期更新相关系列的文章
💝💝💝关注!关注!!请关注!!!请大家关注下博主,您的支持是我不断创作的最大动力!!!
文章目录
- 引言
- Redis 数据备份方式
- RDB 快照(Redis Database Backup)
- 命令与配置
- 案例:定期自动备份
- AOF 日志(Append Only File)
- 命令与配置
- 案例:AOF 日志优化与备份
- 混合使用 RDB 与 AOF
- Redis 数据恢复实践
- RDB 恢复
- AOF 恢复
- 案例:灾难恢复演练
- 结论
引言
在分布式系统和微服务架构中,Redis 以其高性能、低延迟的特点成为了许多应用的首选数据存储解决方案。然而,随着数据量的增长和业务复杂性的提升,数据安全和灾难恢复成为运维人员不可忽视的重要议题。本文将详细介绍 Redis 的数据备份与恢复机制,包括 RDB 快照、AOF 日志、以及混合使用策略,并通过具体案例展示如何在实际环境中实施有效的数据保护措施。
Redis 数据备份方式
RDB 快照(Redis Database Backup)
RDB 是 Redis 提供的一种快照式备份机制,它会在指定的时间点创建整个数据库的数据快照。RDB 文件包含了所有键值对的数据,在 Redis 重启时,可以快速加载 RDB 文件来恢复数据。
命令与配置
SAVE
: 立即执行 RDB 快照。BGSAVE
: 在后台异步执行 RDB 快照,不会阻塞客户端请求。CONFIG SET save <policy>
: 配置 RDB 自动快照策略,如CONFIG SET save "900 1 300 10 60 10000"
表示在900秒内如果有1个key变化,则执行快照;300秒内有10个key变化也执行快照;60秒内有10000个key变化同样执行快照。
案例:定期自动备份
假设我们有一台生产环境的 Redis 服务器,需要每天凌晨执行一次完整的数据备份,可以采用以下策略:
-
在 Redis 配置文件中设置自动快照策略:
save ""
-
使用
cron
定时任务在凌晨执行 BGSAVE 命令:0 0 * * * redis-cli -h <host> -p <port> bgsave > /dev/null 2>&1
这样,每天凌晨都会在 Redis 的数据目录生成最新的 RDB 文件。
AOF 日志(Append Only File)
AOF 是 Redis 的另一种持久化机制,它会记录所有写入操作的命令,当 Redis 重启时,可以通过重放 AOF 文件中的命令来恢复数据。
命令与配置
CONFIG SET appendonly yes
: 开启 AOF 持久化。CONFIG SET appendfsync <policy>
: 设置 AOF 刷新策略,可选值有always
、everysec
、no
。BGREWRITEAOF
: 优化 AOF 文件,去除冗余命令。
案例:AOF 日志优化与备份
为了保证数据的安全性和性能,我们通常将 AOF 刷新策略设为 everysec
,以每秒一次的频率同步数据至磁盘,同时定期执行 BGREWRITEAOF
来优化 AOF 文件。
此外,可以结合 AOF 日志的备份策略,例如,使用 rsync
或其他工具定期将 AOF 文件复制到远程服务器上,实现异地备份。
混合使用 RDB 与 AOF
RDB 和 AOF 各有优势和局限性,实际应用中,通常会结合使用两者,以达到最佳的数据保护效果。
- RDB 适合全量数据恢复,速度快,占用磁盘空间少。
- AOF 更适合增量数据恢复,可以提供更细粒度的数据保护,但文件体积大,恢复时间较长。
Redis 数据恢复实践
RDB 恢复
当 Redis 需要从 RDB 文件恢复数据时,只需在启动时指定 RDB 文件即可。如果 Redis 配置文件中已启用 RDB,那么在正常启动过程中会自动加载最新的 RDB 文件。
AOF 恢复
AOF 恢复相对简单,只要 AOF 功能已开启,Redis 在启动时会自动读取 AOF 文件并重放所有写入命令,从而恢复数据。
案例:灾难恢复演练
假设我们的主 Redis 实例发生硬件故障,需要从备份中恢复数据。我们有以下几种选择:
-
从 RDB 文件恢复:找到最近的 RDB 快照文件,使用该文件启动一个新的 Redis 实例。这种方法快速,但可能会丢失最后一次 RDB 备份后的数据更改。
-
从 AOF 文件恢复:如果 AOF 功能已启用,可以从最新的 AOF 文件恢复数据,这将提供更接近故障前的数据状态。但是,如果 AOF 文件很大,恢复过程可能比较耗时。
-
混合恢复:可以先使用 RDB 文件快速恢复大部分数据,然后应用 AOF 文件中自上次 RDB 快照以来的所有更改,以获得最完整的数据状态。
结论
在设计 Redis 的数据备份与恢复策略时,应综合考虑业务需求、数据安全性和系统性能。RDB 快照适合定期全量数据备份,而 AOF 日志则提供了更细粒度的数据保护。通过合理规划备份策略和定期进行灾难恢复演练,可以有效降低数据丢失的风险,保障业务连续性和数据完整性。
喜欢博主的同学,请给博主一丢丢打赏吧↓↓↓您的支持是我不断创作的最大动力哟!感谢您的支持哦😘😘😘
💝💝💝如有需要请大家订阅我的专栏【Redis系列】哟!我会定期更新相关系列的文章
💝💝💝关注!关注!!请关注!!!请大家关注下博主,您的支持是我不断创作的最大动力!!!
Redis相关文章索引 | 文章链接 |
---|---|
Redis基础教程(一):redis配置 | Redis基础教程(一):redis配置 |
Redis基础教程(二):redis数据类型 | Redis基础教程(二):redis数据类型 |
Redis基础教程(三):redis命令 | Redis基础教程(三):redis命令 |
Redis基础教程(四):redis键(key) | Redis基础教程(四):redis键(key) |
Redis基础教程(五):string字符串 | Redis基础教程(五):string字符串 |
Redis基础教程(六):redis 哈希(Hash) | Redis基础教程(六):redis 哈希(Hash) |
Redis基础教程(七):redis列表(List) | Redis基础教程(七):redis列表(List) |
Redis基础教程(八):redis集合(Set) | Redis基础教程(八):redis集合(Set) |
Redis基础教程(九):redis有序集合 | Redis基础教程(九):redis有序集合 |
Redis基础教程(十):HyperLogLog | Redis基础教程(十):HyperLogLog |
Redis基础教程(十一):Redis 发布订阅 | Redis基础教程(十一):Redis 发布订阅 |
Redis基础教程(十二):Redis事务 | Redis基础教程(十二):Redis事务 |
Redis基础教程(十三):Redis lua脚本 | Redis基础教程(十三):Redis lua脚本 |
Redis基础教程(十四):Redis连接 | Redis基础教程(十四):Redis连接 |
Redis基础教程(十五):Redis GEO地理信息查询与管理 | Redis基础教程(十五):Redis GEO地理信息查询与管理 |
Redis基础教程(十六):Redis Stream | Redis基础教程(十六):Redis Stream |
❤️❤️❤️觉得有用的话点个赞 👍🏻 呗。
❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄
💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍
🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙
相关文章:

Redis基础教程(十七):Redis数据备份与恢复
💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快! 💝Ὁ…...

基于FPGA的千兆以太网设计(1)----大白话解释什么是以太网
1、什么是以太网? 还记得初学以太网的时候,我就被一大堆专业名词给整懵了:什么以太网,互联网,MAC,IP,局域网,万维网,网络分层模型等等等等。慢着!我学的不是以太网吗?怎么出来这么一大堆东西? 啊!以太网究竟是什么?别急,我接下来就尽量用通俗的大白话来给你解释…...

wordpress的restfull API使用教程,之如何用postman调试API,以便能使用vue等前端框架开发主题
文章目录 API开发手册在postman中调试这里以 post 一篇文章为例,讲解如何调试: 步骤 1:生成应用密码步骤 2:配置Postman步骤 3:创建文章 参考链接 API开发手册 官方API手册:https://developer.wordpress.o…...

刷题刷题刷题
P1123 取数游戏 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 思路: 从1,1开始dfs,若行数x>n则立马刷新最大值退出搜索,若y>m则进入下一行从第一列开始搜索即x1,y1,对当前的搜索点x,y的八个方向进行1,因为不能相邻 AC:…...

【Spring Boot】统一异常处理
目录 统一异常处理一. 概念二. 全局异常处理三. 处理特定异常 统一异常处理 一. 概念 其实统一异常是运用了AOP(对某一类事情的集中处理)的思维,简单概括就是在我们进行前后端数据交互的时候,抛出的任何的异常都能够自动捕获然后…...

java —— tomcat 部署项目
一、通过 war 包部署 1、将项目导出为 war 包; 2、将 war 包放置在 tomcat 目录下的 webapps 文件夹下,该 war 包稍时便自动解析为项目文件夹; 3、启动 tomcat 的 /bin 目录下的 startup.bat 文件,此时即可从浏览器访问项目首页…...

数据库的优点和缺点分别是什么
数据库作为数据存储和管理的核心组件,具有一系列显著的优点,同时也存在一些潜在的缺点。以下是对数据库优点和缺点的详细分析: 数据库的优点 数据一致性:数据库通过事务管理、锁机制、并发控制等技术手段,确保多个用户…...

考研数学暑期规划|50天吃透1000+660!
1000660这个组合当然可以 只不过1000的难度并不适合大多数人,很多同学跟的是张宇老师,但是最后却因为张宇1000题太难而改用其他的习题册比如880或者严选题之类的 当然,如果你的目标分数是120,可以去做1000题,因为100…...

GPT-5 一年半后发布?我们可能所受影响与应用领域
前言: IT之家6月22日消息,在美国达特茅斯工程学院周四公布的采访中,OpenAI首席技术官米拉穆拉蒂被问及GPT-5是否会在明年发布,给出了肯定答案并表示将在一年半后发布。此外,穆拉蒂在采访中还把GPT-4到GPT-5的飞跃描述…...

CSS上下悬浮特效
要实现一个上下悬浮的特效,可以使用CSS的keyframes规则和动画属性。以下是一个简单的示例: 代码示例 /* 定义一个名为floating的动画 */ keyframes floating {0% {transform: translateY(0); /* 初始位置 */}50% {transform: translateY(-4px); /* 向上…...

Knife4j的原理及应用详解(三)
本系列文章简介: 在当今快速发展的软件开发领域,API(Application Programming Interface,应用程序编程接口)作为不同软件应用之间通信的桥梁,其重要性日益凸显。随着微服务架构的兴起,API的数量…...

Android约束布局的概念与属性(1)
目录 1.相对定位约束2.居中和偏移约束 约束布局(ConstraintLayout)是当前Android Studio默认的布局方式,也是最灵活的一种布局方式。约束布局推荐使用所见即所得的模式进行布局,约束布局的大部分布局可以通…...

阿里巴巴开源自然语音交互框架;在抱抱脸上使用LivePortrait;58种提示技术的工具库
✨ 1: FunAudioLLM FunAudioLLM是一个为人类和大型语言模型(LLMs)之间自然语音交互打造的语音理解和生成基础框架。 FunAudioLLM 是阿里巴巴集团Tongyi SpeechTeam推出的用于增强人类与大语言模型(LLM)自然语音交互的框架。该框…...

《算法笔记》总结No.5——递归
一.分而治之 将原问题划分为若干个规模较小而结构与原问题相同或相似的子问题,然后分别解决这些子问题,最后合并子问题的解,即可得到原问题的解,步骤抽象如下: 分解:将原问题分解为若干子问题解决&#x…...

鸿蒙小练习
bean对象 export class BannerImage{id:numberurl:stringtargetUrl:stringproductId:numberconstructor(id: number, url: string, targetUrl: string, productId: number) {this.id idthis.url urlthis.targetUrl targetUrlthis.productId productId} }export class d…...

谷粒商城-个人笔记(集群部署篇二)
前言 学习视频:Java项目《谷粒商城》架构师级Java项目实战,对标阿里P6-P7,全网最强学习文档: 谷粒商城-个人笔记(基础篇一)谷粒商城-个人笔记(基础篇二)谷粒商城-个人笔记(基础篇三)谷粒商城-个人笔记(高级篇一)谷粒商城-个…...

Python面试题-7
21. 请解释Python中的元组。 Python中的元组(Tuple)是一种内置的数据结构,它有如下特点: 有序性:元组中的元素是有序的,每个元素都有一个索引,索引从0开始。不可变性:一旦元组被创…...

微信⼩程序的电影推荐系统-计算机毕业设计源码76756
摘 要 随着互联网的普及和移动互联网的发展,人们对于获取信息的便捷性和高效性要求越来越高。电影作为一种受众广泛喜爱的娱乐方式,电影推荐系统的出现为用户提供了更加个性化和精准的电影推荐服务。微信小程序作为一种轻量级应用形式,在用…...

理解与解读李彦宏在2024世界人工智能大会的发言:应用优先于技术
2024年7月4日,世界人工智能大会暨人工智能全球治理高级别会议在上海世博中心举行。百度创始人、董事长兼首席执行官李彦宏在产业发展主论坛上提出了一个引人深思的观点:“大家不要卷模型,要卷应用!”他强调了一个重要的观点&#…...

数字化打破传统,引领企业跨界经营与行业生态盈利
在当今数字化时代,传统的赚货差思路正面临着巨大的挑战。然而,数字化的崛起为企业提供了突破传统束缚的机会,促使其转向跨界经营,并通过行业生态经营获取利润。 首先,数字化打破了传统赚货差思路的局限性。以往&…...

【链表】- 链表相交
1. 对应力扣题目连接 链表相交 2. 实现思路 链表详情: 考虑使用双指针: 解法一: 具体代码,详见3. 实现案例代码解析: 思路:因为链表按照如图的箭头走向,走的总路程是相等的,一…...

【python 学习】快速了解python内置类型
🎬 鸽芷咕:个人主页 🔥 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想,就是为了理想的生活! 文章目录 前言一、内置类型的介绍1.1 类型体系1.2 空类型和None1.3 布尔值 二、内置类型的运算2.1 布尔运算2.2 比较运算符比较…...

npm ERR! code ENOTEMPTY npm ERR! syscall rename npm ERR!
报错: npm ERR! code ENOTEMPTY npm ERR! syscall rename npm ERR! path /home/user/.local/lib/node_modules/pkg npm ERR! dest /home/user/.local/lib/node_modules/.pkg-piikcue3 npm ERR! errno -39 npm ERR! ENOTEMPTY: directory not empty, rename ‘/home/…...

智能井盖采集装置 开启井下安全新篇章
在现代城市的脉络之下,错综复杂的管网系统如同城市的血管,默默支撑着日常生活的有序进行。而管网的监测设备大多都安装在井下,如何给设备供电一直是一个难题,选用市电供电需经过多方审批,选用电池供电需要更换电池包&a…...

C# AGV小车通讯开发的方法
AGV (Automated Guided Vehicle) 小车的通讯开发通常涉及与AGV控制系统或调度系统的数据交换。在C#中实现AGV小车通讯,可以采用多种方法,具体取决于AGV的通信协议和硬件接口。以下是一些常用的开发方法: 1. 串行通讯 (Serial Communication)…...

01-图像基础-颜色空间
1.RGB颜色空间 RGB是一种常用的颜色空间,比如一幅720P的图像,所对应的像素点个数是1280*720,每一个像素点由三个分量构成,分别是R,G,B。 R代表红色分量,G代表绿色分量,B代表蓝色分量,以24位色来…...

双向链表+Map实现LRU
LRU: LRU是Least Recently Used的缩写,即最近最少使用,是一种常用的页面置换算法,选择最近最久未使用的页面予以淘汰。 核心思想: 基于Map实现k-v存储,双向链表中使用一个虚拟头部和虚拟尾部,虚拟头部的…...

HTML(27)——渐变
渐变是多个颜色逐渐变化的效果,一般用于设置盒子模型 线性渐变 属性:background-image : linear-gradient( 渐变方向 颜色1 终点位置, 颜色2 终点位置, ......); 取值: 渐变方向:可选 to 方位名词角度度数 终点位置:可选 百分…...

2024上半年网络工程师考试《应用技术》试题一
阅读以下说明,回答问题。 【说明】 MPLS基于(1)进行转发,进行MPLS标签交换和报文转发的网络设备称为(2),构成MPLS域(MPSDomain)。位于MPLS域边缘、连接其他网络的LSR称为(3),区域内部的LSR称为核心LSR(CoreLSR)IP报文进入MPLS网络时…...

pnpm介绍
PNPM 是一个 JavaScript 包管理器,类似于 npm 和 Yarn。它的全称是 "Performant npm",主要设计目标是优化包的安装和管理过程,以提升速度和效率。PNPM 的主要特点包括: 符号链接(Symlink)&#x…...