iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >Redis数据持久化方式技术解析
  • 840
分享到

Redis数据持久化方式技术解析

2024-04-02 19:04:59 840人浏览 薄情痞子
摘要

RDB(Redis DataBases) 1、RDB是什么: 在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是Snapshot快照,它恢复时是将快照文件直接读到内存里。 Red

RDB(Redis DataBases)

1、RDB是什么:
在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是Snapshot快照,它恢复时是将快照文件直接读到内存里。
Redis会单独创建(fork)一个子进程来进行持久化,会将数据写入到一个临时文件中,持久化过程都结束了,再用这个临时文件替换上次持久化好的文件。整个过程中,主进程是不进行任何io操作的,这就确保了极高的性能,如果需要进行大规模数据的恢复,且对于数据恢复的完整性不是非常敏感,那RDB方式是要比AOF方式更加的高效。RDB的缺点是最后一次持久化后的数据可能丢失。

2、Fork的作用:
Fork的作用是复制一个与当前进程一样的进程。新进程的所有数据(变量、环境变量、程序计数器等)数值都和原进程一致,但是是一个全新的进程,并作为原进程的子进程。

3、Rdb保存的是dump.rdb文件。

4、如何触发RDB快照
(1)配置文件中默认的快照配置:冷拷贝后重新使用(可以cp dump.rdb dump_new.rdb)。
(2)命令save或者bgsave:Save,只管保存其他不管,全部阻塞;bgsave,redis会在后台异步进行快照操作,快照同时还可以响应客户端请求。可以通过lastsave命令获取最后一次成功执行快照的时间。
(3)执行flushall命令,也会产生dump.rdb文件,但里面是空的,无意义。

5、如何恢复: 将备份文件(dump.rdb)移动到redis安装目录并启动服务即可。

6、优势:适合大规模的数据恢复;对数据完整性和一致性要求不高。

7、劣势:在一定间隔时间做一次备份,所以如果redis意外down掉的话,就会丢失最后一次快照后的所有修改。Fork的时候,内存中的数据被克隆了一份,大致2倍的膨胀性需要考虑。

8、如何停止:动态所有停止RDB保存规则的方法:redis-cli config set save “”

总结

在这里插入图片描述

1、RDB是一个非常紧凑的文件。
2、RDB在保存RDB文件时父进程唯一需要做的就是fork出一个子进程,接下来的工作全部由子进程来做,父进程不需要再做其他IO操作,所以RDB持久化方式可以最大化redis的性能。
3、与AOF相比,再恢复大的数据集的时候,RDB方式会更快一些。
4、数据丢失风险大。
5、RDB需要经常fork子进程来保存数据集到硬盘上,当数据集比较大的时候,fork的过程是非常耗时的,可能会导致Redis在一些毫秒级不能响应客户端请求。

AOF(Append Only File)

1、AOF是什么:以日志的形式来记录每个写操作,将Redis执行过的所有写指令记录下来(读操作不记录),只许追加文件但不可以改写文件,redis启动之初会读取该文件重新构建数据,换言之,redis重启的话就根据日志文件的内容将写指令从前到后执行一次以完成数据的恢复工作。

2、rewrite是什么:AOF采用文件追加的方式,文件会越来越大为避免出现此种情况,新增了重写机制,当AOF文件的大小超过所设定的阈值时,Redis就会启动AOF文件的内容压缩,只保留可以恢复数据的最小指令集,可以使用命令bgrewriteaof。

3、重写原理:AOF文件持续增长而过大时,会fork出一条新进程来将文件重写(也是先写临时文件最后再rename),遍历新进程的内存中数据,每条记录有一条的set语句。重写aof文件的操作,并没有读取旧的aof文件,而是将整个内存中的数据库内容用命令的方式重写了一个新的aof文件,这点和快照点数类似。

4、重写的触发机制:Redis会记录上次重写时AOF的大小,默认配置时当AOF文件大小是上次rewrite后大小的一倍且文件大于64MB时触发。

5、优势:
(1)每秒同步:appendfsync always同步持久化每次发生数据变更会被立即记录到磁盘,性能较差但数据完整性比较好。
(2)每次修改同步:appendfsync everysec 异步操作,每秒记录如果一秒内宕机,有数据丢失。
(3)不同步:appendfsync no 从不同步。

6、劣势:
(1)相同数据集的数据而言aof文件要远大于rdb文件,恢复速度慢于rdb。
(2)AOF运行效率要慢于rdb,每秒同步策略效率较好,不同步效率和rdb相同。

总结

在这里插入图片描述

1、AOF文件是一个只进行追加的日志文件。
2、Redis可以再AOF文件体积变得过大时,自动地在后台对AOF进行重写。
3、AOF文件有序地保存了对数据库执行的所有写入操作,这些写入操作以Redis协议的格式保存,因此AOF文件的内容非常容易被人读懂,对文件进行分析也很轻松。
4、对于相同的数据集来说,AOF文件的体积通常要大于RDB文件的体积。
5、根据所使用的fsync策略,AOF的速度可能会慢于RDB。

两种方式的总结

1、RDB持久化方式能够在指定的时间间隔能对你的数据进行快照存储。
2、AOF持久化方式记录每次对服务器写的操作,当服务器重启的时候会重新执行这些命令来恢复原始的数据,AOF文件进行后台重写,使得AOF文件的体积不至于过大。
3、只做缓存:如果你只希望你的数据在服务器运行的时候存在,你也可以不使用任何持久化方式。

以上就是Redis缓存持久化技术解析的详细内容,更多关于redis持久化的资料请关注编程网其它相关文章!

--结束END--

本文标题: Redis数据持久化方式技术解析

本文链接: https://www.lsjlt.com/news/135921.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Redis数据持久化方式技术解析
    RDB(Redis DataBases) 1、RDB是什么: 在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是Snapshot快照,它恢复时是将快照文件直接读到内存里。 Red...
    99+
    2022-11-12
  • redis有几种数据持久化方式
    今天就跟大家聊聊有关redis的数据持久化方式,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。redis提供了两种数据持久化的方式,分别是RDB(Re...
    99+
    2022-10-18
  • redis持久化数据有哪几种方式?
    redis持久化数据有哪几种方式?相信很多人对redis持久化数据的了解处于一知半解状态,小编给大家总结了以下内容。如下资料是关于redis持久化数据的内容。Redis被称为是内存数据库,那是因为它会将其所...
    99+
    2022-10-18
  • redis数据的两种持久化方式对比
    一.概念介绍 redis提供了两种持久化的方式,分别是RDB(Redis DataBase)和AOF(Apend Only File)。 RDB方式 RDB方式是一种快照式的持久化方法,将某一时刻的数据持久...
    99+
    2022-06-04
    两种 持久 方式
  • 浅谈redis内存数据的持久化方式
    一、概述 Redis的强大性能很大程度上都是因为所有数据都是存储在内存中的,然而当Redis重启后,所有存储在内存中的数据将会丢失,在很多情况下是无法容忍这样的事情的。所以,我们需要将内存中的数据持久化!典...
    99+
    2022-10-18
  • Redis持久化方式RDB与AOF详解
    前言Redis提供了两种数据存储方式,分别是:cache-only && persistence;cache-only顾名知义,是用与缓存服务的,数据在服务器终止后将消失,在此模式下将不存在...
    99+
    2022-10-18
  • redis数据持久化的实现方法
    小编给大家分享一下redis数据持久化的实现方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!Redis实现数据持久化的两种实现方式:RDB:指定的时间间隔内保存数据快照AOF:先把命令追加到...
    99+
    2022-10-18
  • redis中有哪些实现数据持久化的方式
    redis中实现数据持久化的方式有:1.RDB方式,通过快照实现数据持久化;2.AOF方式,以日志的形式实现数据持久化;redis中实现数据持久化的方式有以下两种RDB方式RDB方式是通过快照的方式实现数据持久化,当符合一定条件时,redi...
    99+
    2022-10-22
  • Redis RDB与AOF持久化方式详细讲解
    目录1.RDB持久化1.1 RDB文件的保存1.2 RDB文件的载入1.3 RDB持久化时服务器的状态1.4 RDB持久化策略2.AOF持久化2.1 持久化的实现2.2 文件的载入与数据还原2.3 AOF文件的重写1.R...
    99+
    2022-11-22
    RedisRDB与AOF Redis持久化方式
  • 探究Redis两种持久化方式下的数据恢复
        对长期奋战在一线的后端开发人员来说,都知道redis有两种持久化方式RDB和AOF,虽说大家都知道这两种方式大概运作方式,但想必有实操了解得不会太多。     这里是自己实操两种持久化方式的一点点记录。      先看以下...
    99+
    2020-06-02
    探究Redis两种持久化方式下的数据恢复
  • 内存型数据库Redis持久化的示例分析
    这篇文章主要为大家展示了“内存型数据库Redis持久化的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“内存型数据库Redis持久化的示例分析”这篇文章吧...
    99+
    2022-10-18
  • Redis做数据持久化的解决方案及底层原理
    目录数据持久化RDB生成方法savebgsave优点缺点AOFAOF记录过程ServerCron作用server.hz写入策略End之前的文章介绍了Redis的简单数据结构的相关使用...
    99+
    2022-11-12
  • 关于Redis数据库三种持久化方案介绍
    目录一、回顾Redis二、方案一:bgsave三、方案二:配置文件rdb四、方案三:aof总结一、回顾Redis 1、redis的特点 redis是一个内存中的数据结构存储系统。优点...
    99+
    2022-11-13
  • mysql实现数据持久化的方式有哪些
    MySQL实现数据持久化的方式主要有以下几种: 数据库存储:MySQL是一种关系型数据库管理系统,最常见的方式是将数据存储在数据...
    99+
    2023-10-26
    mysql
  • Redis做数据持久化的解决方案及底层原理是什么
    本篇内容介绍了“Redis做数据持久化的解决方案及底层原理是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!目录数据持久化RDB生成方法s...
    99+
    2023-06-20
  • redis中RDB数据持久化的使用方法和应用场景
    和Memcache不同的是,Redis能够让数据持久化到硬盘中。Redis目前提供三种持久化方式,RDB、AOF、RDB-AOF混合持久化。数据的安全及备份是运维工作中的重点,下面来看看这RDB持久化的介绍...
    99+
    2022-10-18
  • SpringBoot内置数据源的持久化与解决方案
    目录数据层解决方案与SQL有关的解决方案SpringBoot提供了3种内嵌的数据源对象供开发者选择内置持久化解决方案Springboot内置数据库数据层解决方案 SQLNoSQL 与...
    99+
    2022-11-13
  • Golang高性能持久化解决方案BoltDB数据库介绍
    目录1. 介绍Bolt2. 示例3. 示例分析4. 总结1. 介绍Bolt BoltDB是纯Go语言实现的持久化解决方案,保存数据至内存映射文件。称之为持久化解决方案不是数据库,因为...
    99+
    2022-11-12
  • Android数据持久化之读写SD卡中内容的方法详解
    本文实例讲述了Android数据持久化之读写SD卡中内容的方法。分享给大家供大家参考,具体如下:前面文章里讲的那三个方法:openFileOutput 、openFileInput 虽然都能通过流对象OutputStream和InputSt...
    99+
    2023-05-31
    android 数据持久化 roi
  • 怎么解析RadonDB分布式数据库核心技术与实现
    怎么解析RadonDB分布式数据库核心技术与实现,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。摘要:随着数据规模的逐步扩大,存储和运维成本逐渐...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作