Redis中的两种持久化方式,为什么需要两种持久化?

redis中有两种持久化(aof和rdb),下面本篇文章带大家了解一下这两种持久化,看看它们的优缺点,介绍一下为什么redis需要两种持久化,希望对大家有所帮助!

Redis中的两种持久化方式,为什么需要两种持久化?

Redis的两种持久化方式

众所周知,Redis中提供了AOF,RDB两种持久化,下面先来简单回顾一下。

RDB持久化

RDB持久化,就是把当前时间点的数据库的状态保存到磁盘中,又称快照持久化。RDB可以手动触发,也可以根据服务器配置定期执行。RDB生成的文件,是一个经过压缩的二进制文件,数据库可以通过该文件还原到该时间点的状态。Redis提供前台RDB持久化命令SAVE和后台RDB持久化命令BGSAVE,前台执行时,Redis的其他命令会被阻塞,而后台执行时,Redis还可以继续处理客户端的命令请求。RDB二进制文件中,保存的是键值对数据,采用经过压缩的自定义编码,带校验。通过od命令可以转化为可读。主从复制时,初始化的全量复制采用RDB文件。

【相关推荐:Redis视频教程】

AOF持久化

AOF持久化,全称是Appen Only File,意思是追加的持久化方式,其中保存的是写命令,而非数据。AOF持久化过程分为命令追加、文件写入、文件同步三个步骤。命令追加:Redis服务端每执行完一个写命令,都会以AOF协议格式将该写命令追加到服务器状态的aof_buf缓冲区末尾。文件写入:Redis中,每结束一个事件循环之前,都会调用flushAppendOnlyFile函数,将aof_buf缓冲区中的内容写入到AOF文件。文件同步:同步sync指的是文件写入到操作系统缓冲区中时,是否直接同步到磁盘中。通过配置,可以选择立即同步、每秒同步、不主动同步而由操作系统控制,这三种同步方式。关于文件I/O缓冲:http://www.php.cn/course/list/54.htmlRedis优先使用AOF文件来恢复数据。AOF文件由于存储命令,且没有经过压缩,其体积要大于RDB文件。AOF文件可以定期采用BGREWRITEAOF重写,减少重复命令、已失效命令,合并命令等。AOF文件支持后台重写,采用fork子进程的形式实现。子进程带有服务器进程的数据副本,再避免使用锁的情况下保证数据安全性。另外也采用AOF重写缓冲区解决了数据不一致。

两种持久化分别的优缺点

RDB的优点

文件体积小,适合拷贝做冷备

相比AOF,备份恢复速度更快

RDB的缺点

丢失数据多

fork子进程来做BGSAVE,消耗一定的内存资源

AOF的优点

丢失数据少

增加了写缓冲区,无需寻址,速度快

append-only,也无需做磁盘寻址,效率高

AOF的缺点

文件体积大

AOF每次都需要做一下写入aof_buf的操作,开启AOF持久化后,QPS会略微降低

Redis为什么需要两种持久化?

经过上面的回顾,我们可以看到,RDB与AOF持久化有明显区别。

存储的内容:RDB存储某一时间点的数据;AOF存储执行的写命令。

文件大小:RDB文件较小;AOF文件较大。

写入方式:RDB可采用前台/后台写入方式;AOF采用每次执行写命令,都将命令存入缓冲区的方式,另外可定期重写。

数据丢失:RDB丢失从宕机到上一次RDB同步之间的所有数据;AOF根据I/O缓冲区所配置的刷新方式,不丢失或丢失1s或几秒的数据。

根据这些对比,可以看到RDB持久化更适合保存一个时间点的数据,在主从复制或者数据全量异地灾备时,拷贝到其他地方,而AOF持久化由于丢失数据较少,比较适合作为本地备份,在Reids挂掉重启时作为故障恢复。这就是我理解的为什么Redis需要两种持久化方式

更多编程相关知识,请访问:编程入门!!

以上就是Redis中的两种持久化方式,为什么需要两种持久化?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2039978.html

(0)
上一篇 2025年2月24日 00:07:53
下一篇 2025年2月19日 11:46:35

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 深入解析Redis中的分布式锁

    本篇文章给大家主要带大家了解一下redis中分布式锁的实现和代码解析,希望对大家有所帮助! Redis 分布式锁 大家项目中都会使用到分布式锁把,通常用来做数据的有序操作场景,比如一笔订单退款(如果可以退多次的情况)。或者用户多端下单。【相…

    2025年2月24日
    200
  • 一起聊聊Redis缓存的淘汰策略

    redis 缓存有哪些淘汰策略?本篇文章就来和大家一起聊聊redis缓存的淘汰策略,介绍缓存策略设置建议,希望对大家有所帮助! Redis(Remote Dictionary Server ),即远程字典服务,是一个开源的使用ANSI C语…

    2025年2月24日
    200
  • 深入浅析Redis中的sentinel故障转移

    本篇文章带大家了解一下redis中的故障转移(sentinel),希望对大家有所帮助! 当两台以上的Redis实例形成了主备关系,它们组成的集群就具备了一定的高可用性:当master发生故障的时候,slave可以成为新的master对外提供…

    2025年2月24日 数据库
    200
  • 聊一聊分布式系统下基于Redis的分布式锁

    加锁了,还有并发问题?redis分布式锁你真的了解?下面本篇文章就来给大家聊一聊分布式系统下基于redis的分布式锁,希望对大家有所帮助! 新接手的项目,偶尔会出现账不平的问题。之前的技术老大临走时给的解释是:排查了,没找到原因,之后太忙就…

    2025年2月24日
    200
  • redis为什么用单线程?为什么那么快?

    什么是redis的单线程?redis为什么用单线程?为什么单线程redis能那么快?下面本篇文章给大家分析分析,希望对大家有所帮助! 1.基本概念 什么是redis的单线程(核心功能在单线程上,并不是所有功能) redis的网络IO和键值对…

    2025年2月24日 数据库
    200
  • 聊聊Redis中怎么实现支持几乎所有加锁场景的分布式锁

    本篇文章给大家介绍一下redis分布式锁的实现方法,希望对大家有所帮助! Hello 大家好,今天给大家分享redisson实现的多类型锁、支持几乎所有加锁场景的redis分布式锁的实现,还支持小型MQ和redis的各种数据操作。【相关推荐…

    2025年2月24日 数据库
    200
  • 一文聊聊Redis中的epoll和文件事件

    本篇文章给大家介绍一下redis中的文件事件,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 事件驱动 Redis 服务器是事件驱动程序,分为文件事件和时间事件 文件事件:socket 的可读可写事件定时任务 【相关推荐:R…

    2025年2月24日
    200
  • 总结分享几款实用Redis可视化工具

    本篇文章总结了几款实用redis可视化工具分享给大家,希望对大家有所帮助,快来收藏吧! 不啰嗦,我们直接开始! 1、命令行 1.1、iredis 利用iredis,用|将redis通过pipe用shell的其他工具,比如jq/fx/rg/s…

    2025年2月24日 数据库
    200
  • 浅谈Redis中的字典、哈希算法和ReHash原理

    本篇文章带大家了解一下redis中的字典、哈希算法和rehash原理,希望对大家有所帮助! Redis 中的字典被广泛用于实现Redis的各种功能,其中包括数据库和哈希键。 字典的底层实现为哈希表,每个字典带有两个哈希表,一个平时使用,另一…

    2025年2月24日
    200
  • 浅析Redis缓存中的8种淘汰策略

    本篇文章带大家来聊聊redis缓存中的8种淘汰策略,看看应该怎么使用它们,希望对大家有所帮助! 我们知道Redis缓存使用内存来保存数据,但内存大小毕竟有限,随着要缓存的数据量越来越大,有限的缓存空间不可避免地会被写满。这时候就需要缓存的淘…

    2025年2月24日
    200

发表回复

登录后才能评论