【Redis】RDB和AOF

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 【Redis】RDB和AOF

Redis是内存数据库,如果不将内存中的数据库状态保存到磁盘,那么一旦服务器进程退出,服务器中的数据库状态也会消失。所以Redis提供了持久化功能!

RDB(Redis DataBase)

在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是行话讲的Snapshot快照,它恢复时是将快照文件直接读到内存里。

Redis会单独创建(fork )一个子进程来进行持久化,会先将数据写入到一个临时文件中,待持久化过程都结束了,再用这个临时文件替换上次持久化好的文件。整个过程中,主进程是不进行任何I0操作的。这就确保了极高的性能。如果需要进行大规模数据的恢复,且对于数据恢复的完整性不是非常敏感,那RDB方式要比AOF方式更加的高效。RDB的缺点是最后一次持久化后的数据可能丢失。

900秒1次

300秒10次

一分钟1W次

save 60 5 主要我们在60s内修改了5次,就会触发生成dump.rdb文件

触发机制

  1. save的规则满足的情况下,会自动触发rdb规则
  2. 执行flushall命令,也就是触发我们的rdb规则
  3. 退出redis,也会产生一个rdb文件

备份就自动生成了一个dump.rdb

如何恢复rdb文件

  1. 只需要将rdb文件放在我们redis启动目录就可以,redis启动的时候会自动检查dump.rdb 恢复其中的数据!
  2. 查看需要存在的位置
127.0.0.1:6379> config get dir
1) "dir"
2) "/usr/local/bin"# 如果在这个目录下存在 dump. rdb文件,启动就会自动恢复其中的数据

优点:

  1. 适合大规模的数据恢复,dump.rdb
  2. 对数据的完整性不高

缺点:

  1. 需要一定的时间间隔进程操作,如果redis意外宕机,最后一次记录就没有了
  2. fork进程的时候,会占用一定的内存空间

AOF(Append Only File)

将我们的所有命令都记录下来,history,恢复的时候就全部再执行一遍

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

AOF保存的是appendonly.aof文件

  1. 默认不开启、手动开启,重启生效
  2. 可以自己选择生成文件的名字

每一秒写一次

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BGqKq4Um-1600050464516)(C:\Users\黄良帅\AppData\Roaming\Typora\typora-user-images\1600046440315.png)]

万一appendonly.aof出错怎么办?

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lx6q9koM-1600050464520)(C:\Users\黄良帅\AppData\Roaming\Typora\typora-user-images\1600046729742.png)]

导致启动不了我们的Redis

解决方法

利用我们的Redis-check-aof --fixe

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GW7CvYTC-1600050464523)(C:\Users\黄良帅\AppData\Roaming\Typora\typora-user-images\1600046658253.png)]

如果我们的aof大于64M,就会fork一个新的进程来将我们的文件进行重写

优点:

  1. 每一次修改都同步,文件的完整会更加的好
  2. 默认开启的是每秒同步一次
  3. 从不同步,效率是最高的

缺点:

  1. 相对于数据文件来说,aof远远大于rdb的内存,修复的速度也比rdb慢
  2. aof运行效率要比rdb慢,所以说redis默认的配置是我们的rdb持久化

扩展


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
27天前
|
存储 NoSQL Redis
保障数据安全,提升性能:探秘Redis AOF持久化机制在在线购物网站的应用
保障数据安全,提升性能:探秘Redis AOF持久化机制在在线购物网站的应用
|
4月前
|
NoSQL 关系型数据库 MySQL
Redis持久化机制 RDB 和 AOF 的选择
Redis持久化机制 RDB 和 AOF 的选择
58 0
|
2天前
|
存储 NoSQL 算法
给我说说Redis持久化机制RDB吧
给我说说Redis持久化机制RDB吧
9 0
|
2月前
|
缓存 NoSQL Redis
[Redis]——Redis持久化的两种方式RDB、AOF
[Redis]——Redis持久化的两种方式RDB、AOF
|
2月前
|
NoSQL 关系型数据库 MySQL
Redis 两种持久化方式 AOF 和 RDB
Redis 两种持久化方式 AOF 和 RDB
|
3月前
|
NoSQL Redis 数据库
Redis的安全网:掌握RDB和AOF的持久化技术【redis第四部分】
Redis的安全网:掌握RDB和AOF的持久化技术【redis第四部分】
121 0
|
4月前
|
缓存 移动开发 NoSQL
Redis持久化——AOF机制详解
Redis提供了RDB和AOF的持久化选项。本文主要介绍AOF的核心概念、同步步骤、保存模式、AOF重写详解及AOF的优缺点,还介绍了RDB和AOF混合方式的运行机制。AOF(Append Only File):以协议文本的方式,将所有对数据库进行过写入的命令(及其参数)记录到 AOF 文件,以此达到记录数据库状态的目的
|
4月前
|
存储 NoSQL 算法
Redis持久化——RDB机制详解
Redis提供了RDB和AOF的持久化选项。本文主要介绍RDB的核心概念、触发方式、文件结构及优缺点。RDB(Redis DataBase) ,意为快照/内存快照,RDB持久化是把当前进程数据生成快照保存到磁盘上的过程
|
4月前
|
NoSQL Redis 数据库
Redis持久化之RDB和AOF操作
【1月更文挑战第9天】 无论是面试还是工作,持久化都是重点! Redis是内存数据库,如果不将内存中的数据库状态保存到磁盘,那么一旦服务器进程退出,服务器中的数据库状态也会消失。所以Redis提供了持久化功能!——RDB(Redis DataBase)和AOF(Append Only File)
141 1
Redis持久化之RDB和AOF操作
|
4月前
|
存储 NoSQL 关系型数据库
Redis持久化策略AOF、RDB详解及源码分析
Redis持久化策略AOF、RDB详解及源码分析