【Redis】三种持久化机制?RDB、AOF、混合?这下弄明白了
  TEZNKK3IfmPf 2024年03月30日 43 0

前言(什么是持久化)


首先来谈谈什么是持久化? 

持久化就是将数据从内存保存到磁盘的过程,其目的就是为了防止数据丢失。

为什么要这样做?因为内存中的数据在重启服务器后就会丢失,而磁盘上的数据则不会,因此为了系统稳定,我们就需要把数据进行持久化。同时持久化功能也是 Redis 和 Memcached 最主要的区别之一,因为 Redis 支持持久化而 Memcached 不支持~

那么 Redis 具体是如何实现持久化的呢?往下看~

一、Redis 持久化


1.1、Redis 持久化方式

Redis 持久化方式主要有以下 3 种: 

  • 快照方式(RDB,RedisDataBase):将某个时刻的内存数据,以二进制的方式写入磁盘;由于是二进制写入磁盘,因此效率较高,但是一旦 Redis 意外终止,就会导致数据部分丢失;
  • 文件追加方式(AOF,AppendOnlyFile):记录所有的操作命令,并以文本的形式追加到文件中;由于是文本形式写入,因此效率较低,又由于 AOF 会记录操作指令,因此保证了数据的完整性。
  • 混合持久化方式:Redis 4.0 之后新增的⽅式,混合持久化是结合了 RDB 和 AOF 的优点,在写入的时候,先把当前数据以 RDB 形式写入文件的开头,在将后续的操作命令以 AOF 的格式存入文件,这样既能保证 Redis 重启时的速度,又能加降低数据丢失的风险。

1.2、持久化策略的设置

在连接服务器终端之后使用 redis-cli 命令开启 Redis 客户端,通过以下命令使用不同的持久化策略:

  • RDB(快照方式):当 AOF 和混合持久化都没有开启的情况下默认是 RDB 持久化策略
  • AOF(文件追加方式):在没有开启混合持久化的情况下,使用 config set appendonly yes 开启;
  • 混合持久化:使用 config set aof-use-rdb-preamble yes 直接开启混合持久化。

1.3、不同持久化策略之间的优缺点

1.3.1、RDB(快照方式)

优点:

  1. RDB 内容为二进制数据,占用内存小,更紧凑,适合作为备份文件
  2. RDB 对灾难恢复非常有用,他是一个紧凑的文件,可以更快的传输到远程服务器进行 Redis 服务。
  3. RDB 可以提高 Redis 的运行速度,每次持久化 Redis 主进程都会 fork() 一个子进程,进行数据持久化到磁盘,Redis 主进程不会执行磁盘 I/O 等操作。
  4. 与 AOF 格式文件相比, RDB 文件可以更快的重启,因为文本形式写入磁盘效率低于二进制方式写入磁盘。

缺点:

  1. 由于 RDB 只能保存某个时间段的数据,因此一旦中途 Redis 服务意外终止,则会丢失一段时间的 Redis 数据。
  2. RDB 需要经常 fork() 才能使用子进程将其持久化在硬盘上,因此一旦数据集过大, fork()可能会很耗时,并且如果再加上 CPU 性能不佳,可能会导致 Redis 停止为客户端服务几毫秒甚至一秒钟。

1.3.2、AOF(文件追加方式)

优点:

  1. AOF 持久化保存的数据更加完整。因为 AOF 提供了三种保存策略:“每次操作保存、每秒种保存一次、跟随系统的持久化策略保存”,其中每秒保存一次,从数据的安全性和性能两方面考虑都是个不错的选择,也是 AOF 的默认策略,即使发生意外,最多丢失 1s 钟的数据;
  2. AOF 采用命令追加的写入方式,所有不会出现文件损坏问题,即使由于意外情况,也可以使用 redis-check-aof 工具轻松修复
  3. AOF  持久化文件,跟容易解析,因为他是把所有 Redis 键值操作命令,以文件的方式存入磁盘,即使不小型使用 flushall 命令删除了所有的键值信息,只要使用 AOF 文件,删除最后的 flushall 命令,重启 Redis 即可恢复之前误删的数据。

缺点:

  1. 对于相同数据集来说,AOP 文件要大于 RDB文件
  2. 在 Redis 负载比较高的情况下, RDB 比 AOF 性能更好。
  3. RDB 使用快照持久化 Redis 数据,而 AOF 使用命令追加到 AOF 文件中,因此, RDB 比 AOF 更健壮

1.3.3、混合持久化

优点:

  1. 结合了 RDB 和 AOF 持久化的优点,开头为 RDB 格式,使得 Redis 可以跟快启动,同时结合 AOF 优点,降低了大量丢失数据的风险

缺点:

  1. AOF 文件中添加了 RDB 格式的内容,使得 AOF 文件可读性变的更差。
  2. 兼容性差。混合持久化 AOF 文件,就不能用在 Redis 4.0 之前的版本了。
【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2024年03月30日 0

暂无评论

推荐阅读
TEZNKK3IfmPf