【Redis】持久化(下)-- AOF

news2024/11/24 11:04:33

文章目录

  • AOF
    • 概念
    • 如何使用AOF
    • AOF工作流程
    • 命令写入演示
    • 文件同步策略
  • `AOF`的重写机制
    • 概念
    • 触发重写机制
      • `AOF`重写流程
  • 启动时数据恢复
  • 混合持久化
  • 总结

AOF

概念

AOF持久化:以独立日志的方式记录每次的写命令,重启时再重新执行AOF文件中的命令达到恢复数据的目的.AOF的主要作用是解决了数据持久化的实时性,目前已经是Redis持久化的主流方式.

如何使用AOF

开启AOF功能需要修改配置文件:appendonly yes,默认情况下不开启.AOF文件名通过appendfilename配置(默认是appendonly.aof)设置.保存目录同时RDB持久化方式一致,通过dir配置指定.(注意:当开启AOF的时候,RDB一般就不会生效了)

  • 打开配置文件vim /etc/redis/redis.conf,将该位置修改为appendonly yes
    在这里插入图片描述

  • 可修改AOF文件名:
    在这里插入图片描述

  • 保存目录:
    在这里插入图片描述

AOF工作流程

在这里插入图片描述

  • 所有的写入命令会追加到aof_buf缓冲区中
  • AOF缓冲区根据对应的策略向硬盘同步操作
  • 随着AOF文件越来越大,需要定期对AOF文件进行重写,达到压缩目的
    • 重写:在最终结果一致的情况下,可以剔除命令中一些比较冗余的操作
  • Redis服务器启动实词,可以加载AOF文件进行数据恢复

命令写入演示

  • 我们在配置文件中打开AOF持久化后,当我们输入命令时,在var/lib/redis目录中自动出现了一个新的目录:appendonlydir
  • 打开appendonlydir目录
    在这里插入图片描述
-rw-r--r-- 1 root root 88 Oct  6 20:39 appendonly.aof.1.base.rdb
-rw-r--r-- 1 root root 73 Oct  6 20:39 appendonly.aof.1.incr.aof
-rw-r--r-- 1 root root 88 Oct  6 20:39 appendonly.aof.manifest
  • appendonly.aof.1.base.rdb:这是 Redis AOF 文件的基础 RDBRedis Database Backup)文件,通常用于在 AOF 恢复时提供一个初始的数据库状态

  • appendonly.aof.1.incr.aof:这是增量 AOF 文件,包含自上次 RDB 快照以来对数据库的所有写操作。它是 AOF核心部分。

  • appendonly.aof.manifest:这是 AOF 文件的清单,包含有关 AOF 文件的元数据,如版本、文件大小等。

注意:AOF命令写入的内容直接是文本协议格式.例如:set key111 11111111111111111; 这条命令,在AOF文件中会追加如下文本:
在这里插入图片描述


疑问1:AOF作为一种实时备份的持久化方式,是否会影响Redis的性能呢?
答案: 不会
原因:

  • AOF先写入内存缓冲区aof_buf中,然后一次性刷入磁盘中,这样可以减少磁盘IO
  • AOF在磁盘中时顺序读写,新的命令会追加到原本的文件中

疑问2:AOF过程中为什么需要aof_buf这个缓冲区?
Redis使用单线程响应命令,如果每次写AOF文件都直接同步到硬盘中,性能就会从内存的读写变成IO读写,性能必然下降.所以,先写入缓冲区中可以有效减少IO次数,同时,Redis还可以提供多种缓冲区同步策略,让用户根据自己的需求做出合理的平衡.

文件同步策略

Redis提供了多种AOF缓冲区同步文件策略,由参数appendfsync来控制.
在配置文件中:
在这里插入图片描述

可配置值说明
always命令写入aof_buf后调用fsync同步,完成后返回
everysec(默认设置)命令写入aof_buf后只执行write操作,不进行fsync.每秒同步线程进行fsync
no命令写入aof_buf后只执行write操作,由OS控制fsync的频率

上述的同步文件策略,数据写入磁盘的频率由高到低,性能由低到高

系统调用writefsync说明:

  • write会触发延迟写机制.Linux内核提供页缓冲区用来提升硬盘IO性能.write操作在写入系统缓冲区后立即返回.同步硬盘操作依赖于系统调度控制,例如:缓冲区页空间写满或者达到了特定的时间周期.同步文件之前,如果此时系统故障宕机,缓冲区内数据将会丢失.(即 将内存中的数据写入到内核的页缓冲区中,再由系统调度控制同步硬盘操作)
  • Fsync针对单个文件操作,做强制硬盘同步,fsync阻塞直到数据写入到硬盘

  • 配置always时,每次写入都要同步AOF文件,性能很差,在一般的SATA硬盘上,只能支持大约几百TPS写入.除非是非常重要的数据,否则不建议配置.
  • 配置为no时,由于操作系统同步策略不可控,虽然提高了性能,但是数据丢失风险大增,除非数据的重要程度很低,否则不建议配置
  • 配置为svseysec,是默认配置,也是推荐配置,兼顾了数据安全性和性能.理论上最多丢失1秒的数据

AOF的重写机制

概念

随着命令不断写入AOF,文件会越来越大,为了解决这个问题,Redis引入了AOF重写机制用来压缩文件的体积.AOF文件重写是把Redis进程内的数据转化为写命令同步到AOF文件中


重写后的AOF文件体积为什么可以变小:

  • 进程内已经超时的数据不再写入到文件中
  • 旧的AOF中的无效命令,例如del,hdel,srem等重写后将会删除,只需要保留数据的最终版本
  • 多条写操作合并为一条,例如:lpush list a,lpush list b,lpush list c可以合并为lpush list a b c.

较小的AOF文件一方面降低了硬盘空间的占用,一方面可以提升启动Redis时数据恢复的速度

触发重写机制

触发重写机制分为:手动触发自动触发

  • 手动触发:调用bgrewriteaof命令
  • 自动触发:根据auto-aof-rewrite-min-sizeauto-aof-rewrite-percentage参数确定自动触发时机(在配置文件中可自行配置)
    • auto-aof-rewrite-min-size:表示触发重写时AOF的最小文件大小,默认为64MB
    • auto-aof-rewrite-percentage:代表当前AOF占用大小相比较上次重写时增加的比例

AOF重写流程

在这里插入图片描述

  • 执行AOF重写请求:如果当前进程正在执行AOF重写,请求不执行.如果当前进程正在执行bgsave操作,冲写命令延迟到bgsave执行结束之后再执行
  • 父进程执行fork创建子进程
  • 重写:不关心原来的AOF文件的状态,子进程只需要把内存中当前的数据获取出来,再以AOF的格式写入到一个新的AOF文件中
    • 主进程fork之后,继续响应其他命令.所有修改操作写入AOF缓冲区之后再根据appendfsync策略同步到硬盘中,保证旧AOF文件机制正确
    • 子进程只有fork之前的所有内存信息,父进程中需要将fork之后这段时间的修改操作写入到AOF重写缓冲区中
  • 子进程根据内存快照,将命令合并到新的AOF文件中去
  • 子进程完成重写
    • 新文件写入后,子进程发送信号给父进程
    • 父进程把AOF重写缓冲区内临时保存的命令追加到新的AOF文件中
    • 用新AOF文件替换老的AOF文件

启动时数据恢复

Redis启动时,会根据RDBAOF文件的内容,进行数据恢复
根据持久化文件进行数据恢复
在这里插入图片描述

混合持久化

混合持久化结合了RDBAOF的特点,按照aof的方式,每一个请求/操作,都记录写入aof-use-rdb-preamble文件中,在触发aof重写之后,就会把当前的内存状态按照rdb二进制格式写入到新的AOF文件中,后续在进行操作,仍然是按照aof文本格式追加到文件后面

总结

  • Redis提供了两种持久化的方案:RDBAOF
  • RDB视为内存快照,产生的内容更为紧凑,占用空间小,恢复速度更快.但是产生RDB开销较大,不适合进行实时持久化,一般用于冷备和主从复制
  • AOF视为对修改命令保存,在恢复时需要重放命令.并且有重写机制定期压缩AOF文件
  • RDBAOF都是用fork来创建子进程,利用Linux子进程拥有父进程内存快照的特点来进行持久化,尽可能不影响主进程继续处理后续命令.

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

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

相关文章

工行企业网银U盾展期后有两个证书问题的解决方法

工行企业网银U盾证书快到期后,可以自助展期,流程可以根据企业网银提示页面操作。操作后,可能存在两个新旧两个证书并存的情况,致使网银转账等操作失败,如图: 其原因是新证书生成后,旧证书没有删…

wsl配置图形显示环境 no $display environment variable

wsl运行fsl,安装好之后,可以使用bet,等命令行进行操作,但是不能使用fsl呼出窗口。 因为 wsl并不像原生linux具有destop桌面,它只有命令行。所以当运行fsl的时候会报错, application-specific initializat…

裁掉数千人、把工作外包给 AI!一年多后,这家巨头的 CEO恳求无人搭理

“对,裁掉几千名员工。” “好的,头儿。” “很好,那么这个人工智能可以做那些前雇员能做的一切事情?” “不,不全是。” “等等,什么?” “你刚刚裁掉的几百人都是硬件工程师,…

k8s的pod的管理和优化

资源管理介绍 在kubernetes中,所有的内容都抽象为资源,用户需要通过操作资源来管理kubernetes。 kubernetes的本质上就是一个集群系统,用户可以在集群中部署各种服务 所谓的部署服务,其实就是在kubernetes集群中运行一个个的容器…

Kubernetes--深入理解Pod资源管理

文章目录 kubectl --helpapi-resourcesapi-versionskubectl explain ... API资源资源规范PodServiceConfigMapSecret 显示资源删除资源详细描述RESTful API Pod资源管理Pod的核心概念Pod资源配置了解Pod运行状况Kubectl get pods xxxxkubectl describe pods xxxkubectl logs -f…

如何彻底掌握 JavaScript 23种设计模式

设计模式是解决特定问题的常用解决方案,它们可以帮助开发者编写更清晰、可维护、可扩展的代码。在 JavaScript 中,常见的设计模式可以分为三大类:创建型模式、结构型模式 和 行为型模式。本文将全面介绍 JavaScript 中常见的设计模式&#xf…

性能剖析利器-Conan|得物技术

作者 / 得物技术 - 仁慈的狮子 目录 一、背景 1. 局限性 2. 向前一步 二、原理剖析 1. 系统架构 2. 工作模式 3. reporter 三、稳定性验证 四、案例分析 五、写在最后 一、背景 线上问题的定位与优化是程序员进阶的必经之路,常见的问题定位手段有日志排查、分布式链…

脑机接口技术的未来与现状:Neuralink、机械手臂与视觉假体的突破

近年来,脑机接口(BCI)技术发展迅速,不仅限于科幻小说和电影,已经逐步进入现实应用。特别是马斯克的Neuralink公司推出的“盲视(Blindsight)”设备,最近获得了FDA的突破性设备认定&am…

IEC104规约的秘密之八----应用任务优先级

所谓应用任务优先级,就是同时出现不同的应用任务时,优先发哪个报文。这里有一个表格,可以做为参考,一般是在子站来实现,子站是数据提供方,需要对各种任务的优先级进行排序,以满足应用的实际需要…

为什么Linux系统下的程序无法在Windows下运行

两个系统的格式不同,格式就是协议,是在固定位置有意义的数据。Linux下可执行文件格式是elf,可使用readelf查看elf文件头 而Windows下的可执行程序是PE格式,是一种可执行文件。 还有一点是Linux下和Win下系统API不同,这…

【CSS】houdini自定义CSS属性实现渐变色旋转动画

现有一段代码&#xff0c;在不旋转整个元素的前提下&#xff0c;渐变背景无法应用动画 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initia…

基于 TOSHIBA eFuse 应用电路(带热关断功能)设计方案

近年来各类消费产品&#xff0c;存储设备&#xff0c;服务器等电路变得越来越密集&#xff0c;越来越灵敏&#xff0c;因此保护功能变得越来越重要&#xff0c;我们开发了是用于过流保护和过温保护的参考设计解决方案。 将介绍参考设计中的两种电路&#xff0c;合在一起2CM*2CM…

jetlinks物联网平台学习5:dtu设备接入及温度报警场景联动

dtu设备接入及温度报警场景联动 1、平台端配置1、新建协议2、新建网络组件3、设备接入网关配置4、新增产品5、导入产品物模型6、新增设备7、场景联动配置7.1、触发规则7.2、触发条件7.3、执行动作 2、平台端验证场景联动 1、平台端配置 下载三个文件 https://hanta.yuque.com…

详解 SPI 机制

SPI(Service Provider Interface) 是 JDK 内置的一种服务提供发现机制&#xff1a;可以用来启用框架扩展和替换组件&#xff0c;主要用于框架中开发。例如&#xff1a;Dubbo、Spring、Common-Logging&#xff0c;JDBC 等都是采用 SPI 机制&#xff0c;针对同一接口采用不同的实…

RTOS系统移植

一、完成系统移植 系统移植上官网寻找合适的系统包&#xff0c;下载后将文件移植入工程文件 二、创建任务句柄、内核对象句柄&#xff08;信号量&#xff0c;消息队列&#xff0c;事件标志组&#xff0c;软件定时器&#xff09;、声明全局变量、声明函数 三、创建主函数&#…

Stable Diffusion绘画 |,IP角色多视图生成技巧(附插件模型)

在游戏设计、小说推文、角色设计里面&#xff0c;很多场景都运用到IP角色的多视图。 人物角色多视图 第1步&#xff0c;输入提示词&#xff1a; 第2步&#xff0c;由于要在同一张图片中生成多角度的并排展示&#xff0c;需要修改图片的分辨率&#xff08;尤其是宽度&#xff…

开源问答类知识付费网站源码系统 带完整的安装代码包以及搭建部署教程

系统概述 近年来&#xff0c;随着互联网的飞速发展&#xff0c;知识付费市场呈现出爆炸式增长。各大知识付费平台如雨后春笋般涌现&#xff0c;涵盖了从教育、科技到生活娱乐等各个领域。用户通过付费获取高质量的知识内容&#xff0c;而内容创作者则通过分享知识获得经济回报…

大模型应用探讨,免费AI写作、一键PPT、免费PDF百种应用、与AI对话

大模型应用平台知识普及, 应用可见评论区 我们生活在一个充满无限可能的数字时代&#xff0c;人工智能技术正在推动着各种创新的边界。大模型应用平台一般包含以下功能。 ## 1. 一键生成论文 写作是学生、研究人员和职场人士都无法避免的任务。大模型应用平台拥有强大的文本生…

如何让算法拥有“记忆”?一文读懂记忆化搜索

✨✨✨学习的道路很枯燥&#xff0c;希望我们能并肩走下来! 文章目录 目录 文章目录 前言 一 什么是记忆化搜索 二 相关题目练习 2.1 斐波那契数&#xff08;详解记忆化搜索&#xff09; ​编辑 解法一&#xff08;递归&#xff09;&#xff1a; 解法二&#xff08;记…

全面整理人工智能(AI)学习路线图及资源推荐,非常详细收藏我这一篇就够了

在人工智能&#xff08;AI&#xff09;飞速发展的今天&#xff0c;掌握AI技术已经成为了许多高校研究者和职场人士的必备技能。从深度学习到强化学习&#xff0c;从大模型训练到实际应用&#xff0c;AI技术的广度和深度不断拓展。作为一名AI学习者&#xff0c;面对浩瀚的知识海…