Redis的持久化及RDB和AOF的使用及选择(四)

Redis的持久化

1. 概述

https://redis.io/topics/persistence

在这里插入图片描述

2. RDB【Redis DataBase】
2.1 什么是RDB

在这里插入图片描述

​ save 900 1

​ save 300 10

​ save 60 10000

​ 这里将配置文件里的三个save都注了,改成save 10 10

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

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

2.2 什么是FORK

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

2.3 保存位置及配置位置

Rdb 保存的是dump.rdb文件

2.4 如何触发RDB快照

在这里插入图片描述
在这里插入图片描述

执行flushall命令,也会产生dump.rdb文件,但里面是空的,无意义

2.5 如何恢复数据

将备份文件 (dump.rdb) 移动到 redis 安装目录并启动服务即可

CONFIG GET dir获取目录

在这里插入图片描述

2.6 优点

适合大规模的数据恢复

对数据完整性和一致性要求不高

2.7 缺点

在一定间隔时间做一次备份,所以如果redis意外down掉的话,就 会丢失最后一次快照后的所有修改

Fork的时候,内存中的数据被克隆了一份,大致2倍的膨胀性需要考虑

3. AOF
3.1 概述

在这里插入图片描述

3.2 原理
  • 以日志的形式来记录每个写操作,将Redis执行过的所有写指令记录下来(读操作不记录),

    只许追加文件但不可以改写文件。redis启动之初会读取改文件重新构建数据,换言之,redis重启的话就根据日志文件的内容将写指令从前到后执行一次一完成数据的恢复工作

3.3保存位置及位置配置

Aof保存的是appendonly.aof文件

在这里插入图片描述

3.4 AOF启动/修复/恢复
  • 正常恢复

    启动:设置yes,修改默认的appendonly no,改为yes

    将有数据的aof文件复制一份保存到对应目录(config get dir)

    恢复:重启redis然后重新加载

  • 异常恢复

    启动:设置Yes 修改默认的appendonly no,改为yes

    备份被写坏的AOF文件

    修复: Redis-check-aof --fix进行修复

    恢复:重启redis然后重新加载

3.5 优势
  • 每修改同步:appendfsync always 同步持久化 每次发生数据变更会被立即记录到磁盘
  • 性能较差但数据完整性比较好
  • 每秒同步:appendfsync everysec 异步操作,每秒记录 如果一秒内宕机,有数据丢失
  • 不同步:appendfsync no 从不同步
3.6 劣势
  • 相同数据集的数据而言aof文件要远大于rdb文件,恢复速度慢于rdb
  • Aof运行效率要慢于rdb,每秒同步策略效率较好,不同步效率和rdb相同
4. 如何选择RDB和AOF
4.1 官方建议

在这里插入图片描述

4.2 整理我们的理解及处理方式
  • RDB持久化方式能够在指定的时间间隔能对你的数据进行快照存储

  • AOF持久化方式记录每次对服务器写的操作,当服务器重启的时候会重新执行这些 命令来恢复原始的数据,AOF命令以redis协议追加保存每次写的操作到文件末尾. Redis还能对AOF文件进行后台重写,使得AOF文件的体积不至于过大

  • 只做缓存:如果你只希望你的数据在服务器运行的时候存在,你也可以不使用任何持久化方式.

4.3 同时开启两种持久化的方式

在这种情况下,当redis重启的时候会优先载入AOF文件来恢复原始的数据, 因为在通常情况下AOF文件保存的数据集要比RDB文件保存的数据集要完整.

RDB的数据不实时,同时使用两者时服务器重启也只会找AOF文件。那要不要只使用AOF呢? 作者建议不要,因为RDB更适合用于备份数据库(AOF在不断变化不好备份), 快速重启,而且不会有AOF可能潜在的bug,留着作为一个万一的手段。

4.4性能建议

因为RDB文件只用作后备用途,建议只在Slave上持久化RDB文件,而且只要15分钟备份一次就够了,只保留save 900 1这条规则。

如果Enalbe AOF,好处是在最恶劣情况下也只会丢失不超过两秒数据,启动脚本较简单只load自己的AOF文件就可以了。代价一是带来了持续的IO,二是AOF rewrite的最后将rewrite过程中产生的新数据写到新文件造成的阻塞几乎是不可避免的。只要硬盘许可,应该尽量减少AOF rewrite的频率,AOF重写的基础大小默认值64M太小了,可以设到5G以上。默认超过原大小100%大小时重写可以改到适当的数值。

如果不Enable AOF ,仅靠Master-Slave Replication 实现高可用性也可以。能省掉一大笔IO也减少了rewrite时带来的系统波动。代价是如果Master/Slave同时倒掉,会丢失十几分钟的数据,启动脚本也要比较两个Master/Slave中的RDB文件,载入较新的那个。新浪微博就选用了这种架构

Slave Replication 实现高可用性也可以。能省掉一大笔IO也减少了rewrite时带来的系统波动。代价是如果Master/Slave同时倒掉,会丢失十几分钟的数据,启动脚本也要比较两个Master/Slave中的RDB文件,载入较新的那个。新浪微博就选用了这种架构

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值