redis数据持久化之RDB大战AOF

华子目录

  • 数据持久化
  • `RDB`
    • 什么是RDB
    • 如何备份
    • Fork
    • 持久化流程
    • `rdb`持久化过程
      • 一、触发`RDB`持久化的方式
      • 二、`RDB`持久化的具体过程
      • 三、`RDB`持久化的优缺点
    • 相关配置
      • 1.db文件名
      • 2.rdb文件和aof文件路径
      • 3.save
        • 示例
      • 4.`stop-writes-on-bgsave-error`
        • `stop-writes-on-bgsave-error` 的配置选项和含义
        • 为什么要设置 `stop-writes-on-bgsave-error`
        • 如何配置 `stop-writes-on-bgsave-error`
        • 注意事项
      • 5.`rdbcompression`
        • `rdbcompression` 参数的作用
        • 如何配置 `rdbcompression`
        • 注意事项
      • 6.`rdbchecksum`
        • 作用
        • 如何配置
        • 注意事项
    • rdb备份与恢复
      • rdb备份
      • rdb恢复
    • rdb优势
    • 劣势
  • AOF
    • 什么是`AOF`
    • 持久化流程
    • 使用AOF
      • 开启AOF(`配置文件`)
        • `appendfsync`选项
      • 使用演示
    • `aof`备份与恢复
      • 备份
      • 恢复
      • 异常恢复
    • rewrite压缩
      • rewrite是什么
      • 重写原理
        • `no-appendfsync-on-rewrite:`
        • 触发机制,何时重写
          • `auto-aof-rewrite-percentage`
          • `auto-aof-rewrite-min-size`
      • 重写流程
    • 优势
    • 劣势
  • 如何选择
  • 总结

数据持久化

Redis主要提供了2种不同形式的持久化方式:

  • rdbRedis database):RDB持久性以指定的时间间隔执行数据集的时间点快照
  • aofAppend Only File):AOF持久化记录服务器接收到的每个写操作,在服务器启动时再次播放重建原始数据集。命令使用与Redis协议本身相同的格式以仅附加方式记录。当日志变得太大时,Redis能够在后台重写日志

RDB

什么是RDB

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

如何备份

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

Fork

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

在这里插入图片描述

  • Linux 程序中,fork()产生一个和父进程完全相同子进程,但子进程在此后多次会被 exec 系统调用,出于效率考虑,Linux 中引入了“写时复制技术”。
    • 一般情况下父进程子进程会共用同一段物理内存,只有进程空间的某一段的内容要发生变化时,才会将父进程内容复制一份给子进程

在这里插入图片描述

持久化流程

在这里插入图片描述
启动:

  • 检查是否存在子进程正在执行 AOF 或者 RDB持久化任务。如果则返回 false
  • 调用 Redis 源码中的 rdbSave方法,方法中执行 fork() 产生子进程执行 RDB 操作。
  • 关于 fork() 中的 Copy-On-Write(写时复制)。

rdb持久化过程

Redis中的RDBRedis Database)持久化过程是将Redis在某个时间点的内存数据集以快照形式写入磁盘文件的过程。以下是RedisRDB持久化的详细过程:

一、触发RDB持久化的方式

RedisRDB持久化可以通过以下几种方式触发:

  1. 手动触发

    • save命令:执行save命令时,Redis会阻塞当前服务器进程,直到RDB文件创建完毕为止。因此,save命令会严重影响Redis服务器的性能,不推荐在生产环境中使用。
    • bgsave命令bgsave命令会创建一个子进程异步执行RDB持久化,这样Redis服务器就可以继续处理客户端请求,而不会阻塞服务器进程。bgsaveRedis RDB持久化的主要方式。
  2. 自动触发

    • 根据配置文件中的save指令Redis的配置文件(redis.conf)中可以设置save指令,用于定义在一定时间内发生指定数量的写操作后自动执行bgsave。例如,save 900 1表示在900秒内如果有至少1个key被改变,则触发RDB持久化。
    • 执行flushallflushdb命令:这两个命令分别用于清空Redis数据库中的所有key或当前选中数据库的key执行后自动触发RDB持久化,生成的RDB文件为
    • 执行shutdown命令且没有开启AOF持久化:在关闭Redis服务器时,如果没有开启AOF持久化,则会自动触发RDB持久化。

二、RDB持久化的具体过程

  1. 创建子进程:当bgsave命令被执行或满足自动触发的条件时,Redisfork一个子进程来进行RDB持久化操作。

  2. 内存数据快照子进程会读取内存中的数据,并将其写入到一个临时RDB文件中。这个过程中,主进程可以继续处理客户端请求,而子进程负责将数据写入磁盘。

  3. 写入数据子进程内存中的数据以二进制格式写入到临时RDB文件中。这个过程通常很快,因为Redis采用了高效的内存管理和数据结构。

  4. 替换旧文件:当临时RDB文件写入完成后,子进程会通知主进程进行文件替换主进程会使用原子操作临时RDB文件替换原来的RDB文件,确保在替换过程中数据的完整性一致性。(是怎样替换掉临时文件的?)

  5. 完成持久化:当文件替换完成后,RDB持久化过程结束。此时,Redis的内存数据已经成功保存磁盘上,即使Redis服务器发生宕机,也可以通过RDB文件恢复数据。

三、RDB持久化的优缺点

优点

  • RDB文件是一个紧凑的二进制文件,存储效率较高。
  • RDB恢复数据的速度比AOF快很多。
  • RDB内部存储的是Redis在某个时间点的数据快照,非常适合用于数据备份、全量复制等场景。

缺点

  • RDB文件生成存在时间间隔,如果Redis服务器在两次RDB持久化之间发生宕机,可能会丢失一定的数据。
  • RDB文件采用二进制格式,存在版本兼容性问题。不同版本的Redis可能无法直接读取或写入由其他版本生成的RDB文件。
  • fork创建子进程时,会存在一定的内存消耗性能影响。在大规模数据场景下,这种影响可能更加明显。

相关配置

  • 当关闭redis服务时,会生成.rdb文件
  • 当开启redis服务时,会生成aof文件
  • 当重启redis服务时,都会生成.rdbaof文件
  • 退出redis数据库也会生成.rdb文件

1.db文件名

快照持久化是Redis中默认开启的持久化方案,根据redis.conf中的配置,快照将被写入dbfilename指定的文件中(默认是dump.rdb文件)。

[root@server ~]# cat /etc/redis.conf | grep dbfilename
dbfilename  dump.rdb

2.rdb文件和aof文件路径

根据redis.conf中的配置,快照将保存在dir选项指定的路径上,我们可以修改为指定目录

[root@server ~]# cat /etc/redis.conf | grep dir
dir   "/usr/local/redis/data"
  • 注意:由于此路径是一个相对路径,它会根据执行命令所在目录来生成dump.rdb文件,因此建议改为一个固定位置,如:/usr/local/redis/data目录必须存在

3.save

  • 格式
save   秒   写操作次数
save 900 1                       # 在900s内如果有1条数据被写入,则产生一次快照。
save 300 10                      # 在300s内如果有10条数据被写入,则产生一次快照
save 60 10000                    # 在60s内如果有10000条数据被写入,则产生一次快照
示例

我们把持久化的策略修改为 save 30 5,表示 30 秒内写入 5 条数据就产生一次快照,也就是生成rdb文件。

  • 修改好的保存并重启 redis 服务,然后打开会话,执行如下命令:
127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> set k2 v2
OK
127.0.0.1:6379> set k3 v3
OK
127.0.0.1:6379> set k4 v4
OK
127.0.0.1:6379> set k5 v5
OK
127.0.0.1:6379> set k6 v6
OK

然后查看 dump.rdb 文件的大小,就可以发现文件快照已经产生了。

[root@server ~]# cd /usr/local/redis/data/
[root@server data]# ls
dump.rdb

问题:是否这 6 条数据都持久化了?

  • 答:只持久化了前 5 条数据,最后 1 条数据没有持久化。

注意:Redis 中持久化命令有两种:

  • save:手动保存,只管保存不管其它,所有操作全部阻塞。不建议使用。
  • bgsave:自动保存,Redis会在后台异步进行快照操作, 快照同时还可以响应客户端请求。

4.stop-writes-on-bgsave-error

stop-writes-on-bgsave-errorRedis 配置文件中的一个参数,用于控制在后台保存(bgsave)过程中发生错误时 Redis 的行为。具体来说,这个参数决定了当 Redis 无法将内存中的数据写入磁盘(即 bgsave 操作失败)时,是否应该停止接受新的写操作。

stop-writes-on-bgsave-error 的配置选项和含义
  • yes(默认值):当 bgsave 操作失败时,Redis 将停止接受新的写操作。这是为了提醒管理员注意,可能由于磁盘空间不足、权限问题或其他 I/O 错误导致的数据持久化失败。
  • no:即使 bgsave 操作失败,Redis 也会继续接受新的写操作。这可能会导致数据丢失的风险增加,因为未成功持久化的数据在 Redis 重启后将无法恢复。
为什么要设置 stop-writes-on-bgsave-error
  • 数据安全性:通过停止写操作,stop-writes-on-bgsave-error 参数可以确保在数据持久化失败时,管理员能够及时发现并处理问题,从而避免数据丢失。
  • 系统稳定性:在磁盘空间不足或存在其他 I/O 错误的情况下,继续接受写操作可能会进一步加剧系统资源的紧张状况,甚至导致 Redis 服务崩溃。
如何配置 stop-writes-on-bgsave-error

stop-writes-on-bgsave-error 参数可以在 Redis 的配置文件中(通常是 redis.conf)进行设置。你可以通过编辑配置文件来更改此参数的值,然后重启 Redis 服务以应用更改。

例如,要将 stop-writes-on-bgsave-error 设置为 no,你可以在 redis.conf 文件中找到该参数并将其值更改为 no

stop-writes-on-bgsave-error no

然后,保存配置文件并重启 Redis 服务。

注意事项
  • 在更改 stop-writes-on-bgsave-error 参数之前,请确保你了解更改该参数可能带来的后果,并根据你的实际需求和系统环境做出决策。
  • 如果你选择将 stop-writes-on-bgsave-error 设置为 no,请确保你的系统有足够的监控和告警机制,以便在数据持久化失败时能够及时发现并处理。

综上所述,stop-writes-on-bgsave-error 是一个重要的 Redis 配置参数,它关系到数据的安全性和系统的稳定性。在配置和使用 Redis 时,请务必注意该参数的设置。

5.rdbcompression

rdbcompressionRedis 配置文件中用于控制是否对 RDB 文件进行压缩的参数。在 Redis 中,RDBRedis Database)持久化是一种将内存中的数据以快照的形式保存到磁盘上的方式,以确保数据的安全性和持久性。

rdbcompression 参数的作用
  • rdbcompression 设置为 yes 时,Redis 会在生成 RDB 文件时自动对其进行压缩。这有助于减小 RDB 文件的大小,节省存储空间,但可能会增加 CPU 的负担,因为压缩过程需要消耗计算资源。
  • rdbcompression 设置为 no 时,Redis 将不会压缩 RDB 文件。这可能会导致 RDB 文件占用更多的磁盘空间,但可以减少 CPU 的负担,提高 Redis 的性能。
如何配置 rdbcompression

要在 Redis 中配置 rdbcompression,需要编辑 Redis 的配置文件(通常是 redis.conf),并找到 rdbcompression 这一行。然后,将其值设置为 yesno,以启用或禁用 RDB 文件的压缩。

例如:

rdbcompression yes

或者

rdbcompression no
注意事项
  • 在修改 Redis 配置文件后,需要重启 Redis 服务以使配置生效。
  • 压缩 RDB 文件虽然可以节省存储空间,但可能会对 Redis 的性能产生一定影响。因此,在配置 rdbcompression 时,需要根据实际情况进行权衡。
  • Redis 默认使用 LZF 算法对 RDB 文件进行压缩,但也可以通过安装第三方模块或修改 Redis 源码来支持其他压缩算法。

6.rdbchecksum

rdbchecksumRedis 配置文件中用于控制是否对 RDB 文件进行 CRC64 校验的参数。以下是关于 rdbchecksum 的详细解释:

作用
  • rdbchecksum 设置为 yes 时,Redis 在存储 RDB 快照后,会使用 CRC64 算法对文件内容进行校验。这样做可以确保 RDB 文件的完整性和正确性,但会增加大约 10% 的性能消耗,因为校验过程需要额外的计算资源。
  • rdbchecksum 设置为 no 时,Redis 将不会对 RDB 文件进行 CRC64 校验。这可以提高 Redis 的性能,但可能会降低数据的安全性,因为如果 RDB 文件在存储或传输过程中被损坏,Redis 将无法检测到这一点。
如何配置

要在 Redis 中配置 rdbchecksum,需要编辑 Redis 的配置文件(通常是 redis.conf),并找到 rdbchecksum 这一行。然后,将其值设置为 yesno,以启用或禁用 RDB 文件的 CRC64 校验。

例如:

rdbchecksum yes

或者

rdbchecksum no
注意事项
  • 在修改 Redis 配置文件后,需要重启 Redis服务以使配置生效。
  • 考虑到数据的安全性和完整性,通常建议将 rdbchecksum 设置为 yes,尽管这可能会带来一定的性能开销。
  • 在高并发或性能要求极高的场景下,如果确信 RDB 文件在存储和传输过程中不会受到损坏,也可以考虑将 rdbchecksum 设置为 no 以提高性能。

rdb备份与恢复

rdb备份

首先执行如下命令来清空数据:

127.0.0.1:6379> flushdb

删除之前的dump.rdb文件

[root@server data]# rm -rfv dump.rdb
已删除 'dump.rdb'

然后再重新添加如下数据:

127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> set k2 v2
OK
127.0.0.1:6379> set k3 v3
OK
127.0.0.1:6379> set k4 v4
OK
127.0.0.1:6379> set k5 v5
OK
127.0.0.1:6379> set k6 v6
OK

接着执行如下命令来备份 dump.rdb

[root@server data]# cp dump.rdb dump.rdb.back

最后把 Redis 服务关闭

[root@server ~]# systemctl stop redis

然后把 dump.rdb 文件删除

[root@server data]# rm -rfv dump.rdb
已删除 'dump.rdb'

rdb恢复

先重启 Redis 服务

[root@server ~]# systemctl start redis

查看(发现无数据)

[root@server ~]# redis-cli
127.0.0.1:6379> keys *
(empty array)

停止服务

[root@server ~]# systemctl stop redis

删除dump.rdb(因为停止服务时会备份dump.rdb

[root@server data]# rm -rfv dump.rdb
已删除 'dump.rdb'

将之前备份的文件进行还原

[root@server data]# mv dump.rdb.back dump.rdb
[root@server data]# ls
dump.rdb

再重启redis服务

[root@server ~]# systemctl start redis

查看

[root@server ~]# redis-cli
127.0.0.1:6379> keys *
1) "k4"
2) "k1"
3) "k2"
4) "k5"
5) "k3"
127.0.0.1:6379> get k1
"v1"
127.0.0.1:6379> get k5
"v5"
127.0.0.1:6379> get k6     #证明K6没有备份
(nil)
127.0.0.1:6379>

rdb优势

RDB方式适合大规模的数据恢复,并且对数据完整性和一致性要求不高更适合使用。

  • 节省磁盘空间
  • 恢复速度快

劣势

  • Fork的时候,内存中的数据克隆了一份,大致2倍的膨胀性需要考虑
  • 虽然Redisfork时使用了写时拷贝技术,但是如果数据庞大时还是比较消耗性能
  • 在备份周期在一定间隔时间做一次备份,所以如果Redis意外down掉的话,就会丢失最后一次快照后的所有修改

AOF

什么是AOF

  • 日志的形式来记录每个操作(增量保存),将Redis执行过的所有写指令记录下来(读操作不记录), 只追加文件但不可以改写文件Redis启动之初读取该文件重新构建数据。简单说,Redis 重启时会根据日志文件的内容将写指令前到后执行一次以完成数据的恢复工作
  • Redis的默认配置中,AOFAppend Only File)持久化机制是没有开启的,要想使用AOF持久化需要先开启此功能。AOF持久化会将被执行的写命令写到AOF文件末尾,以此来记录数据发生的变化,因此只要Redis从头到尾执行一次AOF文件所包含的所有写命令,就可以恢复AOF文件的记录的数据集。

持久化流程

在这里插入图片描述

  • 客户端的请求命令会被 append 追加到 AOF缓冲区内。
  • AOF缓冲区根据 AOF 持久化策略 [always,everysec,no] 将操作sync同步到磁盘的AOF文件中。
  • AOF文件大小超过重写策略或手动重写时,会对 AOF 文件 rewrite 重写,压缩AOF文件容量
  • Redis服务重启时,会重新 load 加载 AOF文件中的写操作达到数据恢复的目的。

使用AOF

  • 当关闭redis服务时,会生成.rdb文件
  • 当开启redis服务时,会生成aof文件
  • 当重启redis服务时,都会生成.rdbaof文件
  • 退出redis数据库也会生成.rdb文件

开启AOF(配置文件

修改 redis.conf 配置文件:

  • 通过修改redis.conf配置中appendonly yes来开启AOF持久化
[root@server ~]# cat /etc/redis.conf | grep appendonly
appendonly   yes
  • 通过appendfilename指定日志文件名字(默认为appendonly.aof
[root@server ~]# cat /etc/redis.conf | grep appendfilename
appendfilename "appendonly.aof"
  • AOF文件存储的目录
[root@server ~]# cat /etc/redis.conf | grep appenddirname
appenddirname "appendonlydir"
  • 通过appendfsync指定日志记录频率
[root@server ~]# cat /etc/redis.conf | grep appendfsync
appendfsync everysec
appendfsync选项
选项同步频率
always每个redis写命令都要同步写入硬盘,严重降低redis速度
everysec每秒执行一次同步显式的将多个写命令同步到磁盘
no操作系统决定何时同步
  • always选项,每个redis写命令都会被写入AOF文件中,好处是当发生系统崩溃时数据丢失减至最少,缺点是这种策略会产生大量I/O操作,会严重降低服务器的性能
  • everysec选项,以每秒一次的频率AOF文件进行同步,可以保证系统崩溃时只会丢失一秒左右的数据,并且 Redis 每秒执行一次同步对服务器几乎没有任何影响
  • no选项,完全由操作系统决定什么时候同步AOF日志文件,这个选项不能给服务器性能带来多大的提升,反而会增加系统崩溃时数据丢失的数量

使用演示

  • 先开启AOF功能
[root@server ~]# vim /etc/redis.conf
appendonly   yes[root@server ~]# systemctl restart redis
  • 配置好后,停止 Redis 服务,然后再重新开启 Redis 服务后,就可以在 RDB 生成的同目录下(/usr/local/redis/data)会生成一个 appenddirname 指定的目录
[root@server ~]# cd /usr/local/redis/data/
[root@server data]# ls
appendonlydir  dump.rdb[root@server data]# cd appendonlydir/
[root@server appendonlydir]# ls
appendonly.aof.1.base.rdb    appendonly.aof.1.incr.aof     appendonly.aof.manifest
  • 使用客户端连接 Redis 服务,然后执行:
127.0.0.1:6379> keys *
(empty array)
  • 发现没有任何数据。这说明:如果 RDB 和 AOF 文件同时存在,Redis 默认使用的是 AOF文件

aof备份与恢复

备份

AOF的备份机制和性能虽然和RDB不同,但是备份和恢复的操作同RDB一样:都是拷贝备份文件,需要恢复时再拷贝到Redis工作目录下,启动系统即加载

  • 首先添加数据:
127.0.0.1:6379> set k11 v11
OK
127.0.0.1:6379> set k12 v12
OK
127.0.0.1:6379> set k13 v13
OK
127.0.0.1:6379> set k14 v14
OK
127.0.0.1:6379> set k15 v15
OK
  • 然后停止 Redis 服务,并重命名文件
[root@server ~]# redis-cli shutdown
[root@server ~]# cd /usr/local/redis/data
[root@server data]# mv appendonly.aof appendonly.aof.back

恢复

  • 重新把 aof 文件改名回来,再重启 Redis 服务,连接客户端:
127.0.0.1:6379> keys *
1) "k11"
2) "k12"
3) "k13"
4) "k14"
5) "k15"
  • 发现确实可在恢复。

异常恢复

  • 如遇到 AOF 文件被损坏,可以通过 /usr/local/bin/redis-check-aof --fix .aof文件 进行恢复。
  • 首先我们人为的在 appendonly.aof 中任意添加一点内容,如:
vim appendonly.aof# 在文件最后添加
redis-aof
  • 保存退出后关闭 Redis 服务后再重启 Redis 服务,并用客户端进行连接。这时会发现连接出错:
[root@server ~]# redis-cli
Could not connect to Redis at 127.0.0.1:6379:Connection refused.
  • 这时我们需要对 appendonly.aof 文件进行修复:
[root@server ~]# redis-check-aof --fix  /usr/local/redis/data/appendonly.aof
  • 在提示中输入 y 即可。
  • 修复后再次重启 Redis 服务,并连接客户端就可以了。
  • 但是这个修复无法做到百分百修复!会丢弃一小部分

rewrite压缩

rewrite是什么

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

重写原理

  • AOF文件持续增长而过大时,会fork出一条新进程来将文件重写(也是先写临时文件最后再 rename),redis 4.0 版本后的重写,就是把rdb 的快照,以二级制的形式附在新的aof头部,作为已有的历史数据,替换掉原来的流水账操作。
no-appendfsync-on-rewrite:
  • 如果 no-appendfsync-on-rewrite=yes ,表示不写入aof文件只写入缓存,用户请求不会阻塞,但是在这段时间如果宕机会丢失这段时间的缓存数据。 这样做可以降低数据安全性,提高性能。
  • 如果 no-appendfsync-on-rewrite=no, 还是会把数据往磁盘里刷,但是遇到重写操作,可能会发生阻塞。这样做可以数据安全,但是性能降低。
触发机制,何时重写
  • Redis会记录上次重写时的AOF大小,默认配置是当AOF文件大小是上次rewrite后大小的一倍且文件大于64M时触发
  • 重写虽然可以节约大量磁盘空间,减少恢复时间。但是每次重写还是有一定的负担的,因此设定Redis满足一定条件才会进行重写。
auto-aof-rewrite-percentage
  • auto-aof-rewrite-percentage:设置重写的基准值,文件达到100%时开始重写文件是原来重写后文件的2倍时触发
auto-aof-rewrite-min-size
  • auto-aof-rewrite-min-size:设置重写基准值,最小文件64MB达到这个值开始重写

例如:文件达到70MB开始重写,降到50MB,下次什么时候开始重写?100MB

  • 系统载入时或者上次重写完毕时Redis会记录此时AOF大小,设为base_size,如果RedisAOF当前大小>= base_size +base_size*100% (默认)且当前大小>=64mb(默认)的情况下,Redis会对AOF进行重写。

重写流程

  • bgrewriteaof触发重写,判断是否当前有bgsave或bgrewriteaof在运行,如果有,则等待该命令结束后再继续执行。
  • 主进程fork出子进程执行重写操作,保证主进程不会阻塞。
  • 子进程遍历redis内存中数据到临时文件,客户端的写请求同时写入aof_buf缓冲区和aof_rewrite_buf重写缓冲区保证原AOF文件完整以及新AOF文件生成期间的新的数据修改动作不会丢失。
  • 子进程写完新的AOF文件后,向主进程发信号,父进程更新统计信息。主进程把aof_rewrite_buf中的数据写入到新的AOF文件。
  • 使用新的AOF文件覆盖旧的AOF文件,完成AOF重写。

在这里插入图片描述

优势

  • 备份机制更稳健,丢失数据概率更低。
  • 可读的日志文本,通过操作AOF稳健,可以处理误操作。

劣势

  • 比起RDB占用更多的磁盘空间
  • 恢复备份速度要慢
  • 每次读写都同步的话,有一定的性能压力
  • 存在个别Bug,造成恢复不能。

如何选择

  • RDB持久化方式能够在指定的时间间隔能对你的数据进行快照存储
  • AOF持久化方式记录每次对服务器的操作,当服务器重启的时候会重新执行这些命令来恢复原始的数据,AOF命令以redis协议追加保存每次写的操作到文件末尾.
  • Redis还能对AOF文件进行后台重写,使得AOF文件的体积不至于过大
  • 只做缓存:如果你只希望你的数据在服务器运行的时候存在,你也可以不使用任何持久化方式.
  • 同时开启两种持久化方式
  • 在这种情况下,当redis重启的时候会优先载入AOF文件来恢复原始的数据, 因为在通常情况下AOF文件保存的数据集要比RDB文件保存的数据集要完整.
  • RDB的数据不实时,同时使用两者时服务器重启也只会找AOF文件。那要不要只使用AOF呢?
    • 建议不要,因为RDB更适合用于备份数据库(AOF在不断变化不好备份), 快速重启,而且不会有AOF可能潜在的bug,留着作为一个万一的手段。

总结

  • RDB 持久化方式能够在指定的时间间隔内对你的数据进行快照存储
  • AOF 持久化方式记录每次对服务器写的操作,当服务器重启的时候会重新执行这些命令来恢复原始的数据,AOF命令以Redis 协议追加保存每次写的操作到文件末尾,Redis还能对AOF文件进行后台重写,使得AOF文件的体积不至于过大。
  • 只做缓存,如果你只希望你的数据在服务器运行的时候存在,你也可以不使用任何持久化
  • 同时开启两种持久化方式
    • 在这种情况下,当redis重启的时候会优先载入AOF文件来恢复原始的数据,因为在通常情况下AOF文件保存的数据集要比RDB文件保存的数据集要完整。
    • RDB 的数据不实时,同时使用两者时服务器重启也只会找AOF文件,那要不要只使用AOF呢?建议不要,因为RDB更适合用于备份数据库(AOF在不断变化不好备份),快速重启,而且不会有AOF可能潜在的Bug,留着作为一个万一的手段。
  • 性能建议
    • 因为RDB文件只用作后备用途,建议只在Slave上持久化RDB文件,而且只要15分钟备份一次就够了,只保留 save 900 1 这条规则。
    • 如果Enable AOF ,好处是在最恶劣情况下也只会丢失不超过两秒数据,启动脚本较简单只load自己的AOF文件就可以了,代价一是带来了持续的IO,二是AOF rewrite 的最后将 rewrite 过程中产生的新数据写到新文件造成的阻塞几乎是不可避免的。只要硬盘许可,应该尽量减少AOF rewrite的频率,AOF重写的基础大小默认值64M太小了,可以设到5G以上,默认超过原大小100%大小重写可以改到适当的数值。
    • 如果不Enable AOF ,仅靠 Master-Slave Repllcation 实现高可用性也可以,能省掉一大笔IO,也减少了rewrite时带来的系统波动。代价是如果Master/Slave 同时倒掉,会丢失十几分钟的数据,启动脚本也要比较两个 Master/Slave 中的 RDB文件,载入较新的那个,微博就是这种架构。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3247575.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

Unity3d开发google chrome的dinosaur游戏

游戏效果 游戏中: 游戏中止: 一、制作参考 如何制作游戏?【15分钟】教会你制作Unity小恐龙游戏!新手15分钟内马上学会!_ unity教学 _ 制作游戏 _ 游戏开发_哔哩哔哩_bilibili 二、图片资源 https://download.csdn.…

ELK企业级日志分析

目 录 一、ELK简介 1.1 elasticsearch简介 1.2 logstash简介 1.3 kibana简介 1.4 ELK的好处 1.5 ELK的工作原理 二、部署ELK 2.1 部署elasticsearch(集群) 2.1.1 修改配置文件 2.1.2 修改系统参数 2.1.2.1 修改systemmd服务管理器 2.1.2.2 性能调优参数 2.1.2.3 …

电源模块企业该如何解决测试中的痛点问题?

根据研究发现,超过76%的企业在进行测试时会对产品质量、可靠性和测试速度这三项核心指标尤为重视。但是随着近几年的发展,目前的测试方法和措施对于这三项指标的测试远远无法达到企业的预期。被测产品的整体质量参差不齐、测试数据的可靠性以及测试的速度…

vue 如何做一个动态的 BreadCrumb 组件,el-breadcrumb ElementUI

vue 如何做一个动态的 BreadCrumb 组件 el-breadcrumb ElementUI 一、ElementUI 中的 BreadCrumb 定义 elementUI 中的 Breadcrumb 组件是这样定义的 <template><el-breadcrumb separator"/"><el-breadcrumb-item :to"{ path: / }">主…

yearrecord——一个类似痕迹墙的React数据展示组件

介绍一下自己做的一个类似于力扣个人主页提交记录和GitHub主页贡献记录的React组件。 下图分别是力扣个人主页提交记录和GitHub个人主页的贡献记录&#xff0c;像这样类似痕迹墙的形式可以比较直观且高效得展示一段时间内得数据记录。 然而要从0实现这个功能还是有一些麻烦得…

【数据结构】详解堆

一、堆的概念 堆(Heap)是计算机科学中一类特殊的数据结构的统称。堆通常是一个可以被看做一棵 完全二叉树的 数组对象。 堆是非线性数据结构&#xff0c;相当于一维数组&#xff0c;有两个直接后继。 如果有一个关键码的集合K { k₀&#xff0c;k₁&#xff0c;k₂ &#xff0…

PCB(印制电路板)制造涉及的常规设备

印制电路板&#xff08;PCB&#xff09;的制造涉及多种设备和工艺。从设计、制作原型到批量生产&#xff0c;每个阶段都需要不同的专业设备。以下是一些在PCB制造过程中常见的设备&#xff1a; 1. 计算机辅助设计&#xff08;CAD&#xff09;软件&#xff1a; - 用于设计PC…

3D问界—MAYA制作铁丝栅栏(透明贴图法)

当然&#xff0c;如果想通过建立模型法来实现铁丝栅栏的效果&#xff0c;也不是不行&#xff0c;可以找一下栅栏建模教程。本篇文章主要是记录一下如何使用透明贴图来实现创建铁丝栅栏&#xff0c;主要应用于场景建模&#xff0c;比如游戏场景、建筑场景等大环境&#xff0c;不…

问题清除指南|成功解决pipmatplotlib因为ConnectTimeoutError更新失败问题

前言&#xff1a;跑baseline需要升级matplotlib和pip&#xff0c;在此记录一个错误和一个「别致」的解决方案。 北京时间 14:00 左右&#xff0c;在终端环境中运行命令python -m pip install --upgrade pip&#xff0c;报错&#xff1a; 多次尝试&#xff0c;未果。 隔天上午 0…

Qt支持LG高级汽车内容平台

Qt Group与LG 电子&#xff08;简称LG&#xff09;正携手合作&#xff0c;将Qt软件框架嵌入其基于 webOS的ACPLG车载娱乐平台&#xff0c;用于应用程序开发。该合作旨在让原始设备制造商&#xff08;OEM&#xff09;的开发者和设计师能为汽车创建更具创新性的沉浸式汽车内容流媒…

1-2、truffle与webjs亲密接触(truffle智能合约项目实战)

1-2、truffle与webjs亲密接触&#xff08;truffle智能合约项目实战&#xff09; 5&#xff0c;web3调用智能合约6&#xff0c;Ganache 5&#xff0c;web3调用智能合约 在前面已经完成简单的合约编写 使用web3调用此函数 Web端的代码使用web3进行智能合约的访问 首先在cmd以…

SCI一区级 | Matlab实现SSA-CNN-GRU-Multihead-Attention多变量时间序列预测

目录 效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.【SCI一区级】Matlab实现SSA-CNN-GRU-Multihead-Attention麻雀算法优化卷积门控循环单元融合多头注意力机制多变量时间序列预测&#xff0c;要求Matlab2023版以上&#xff1b; 2.输入多个特征&#xff0c;输出单个…

数据结构之细说链表

1.1顺序表的问题以及思考 经过上一篇顺序表的学习&#xff0c;我们知道顺序表还是有很多缺点 顺序表的缺点&#xff1a; 1.中间/头部的插入删除&#xff0c;实际复杂度为O(N) 2.增容需要申请新空间&#xff0c;拷贝数据&#xff0c;释放旧空间。会有不小的消耗 3.扩容一般…

R语言包AMORE安装报错问题以及RStudio与Rtools环境配置

在使用R语言进行AMORE安装时会遇到报错&#xff0c;这时候需要采用解决办法&#xff1a; AMORE包安装&#xff0c;需要离线官网下载安装包&#xff1a; Index of /src/contrib/Archive/AMORE (r-project.org)https://cran.r-project.org/src/contrib/Archive/AMORE/ 一、出现…

AI绘画入门实践|Midjourney 的模型版本

模型分类 Midjourney 的模型主要分为2大类&#xff1a; 默认模型&#xff1a;目前包括&#xff1a;V1, V2, V3, V4, V5.0, V5.1, V5.2, V6 NIJI模型&#xff1a;目前包括&#xff1a;NIJI V4, NIJI V5, NIJI V6 模型切换 你在服务器输入框中输入 /settings&#xff1a; 回车后…

DETR算法解读——Transformer在目标检测任务的首次应用

论文&#xff1a;End-to-End Object Detection with Transformers 作者&#xff1a;Nicolas Carion, Francisco Massa, Gabriel Synnaeve, Nicolas Usunier, Alexander Kirillov, Sergey Zagoruyko 机构&#xff1a;Facebook AI 链接&#xff1a;https://arxiv.org/abs/2005.12…

【STL详解 —— map和set的使用】

STL详解 —— map和set的使用 关联式容器键值对setset的介绍set的使用set的模板参数列表set的构造set的迭代器set的容量set的修改操作 mapmap的介绍map的使用map的模板参数列表map的构造map的迭代器map的容量与元素访问map中元素的修改 multisetmultimap 关联式容器 在初阶阶段…

Camera Raw:首选项

Camera Raw 首选项 Preferences提供了丰富的配置选项&#xff0c;通过合理设置&#xff0c;可以显著提升图像处理的效率和效果。根据个人需求调整这些选项&#xff0c;有助于创建理想的工作环境和输出质量。 ◆ ◆ ◆ 打开 Camera Raw 首选项 方法一&#xff1a;在 Adobe Bri…

纯硬件一键开关机电路的工作原理

这是一个一键开关机电路: 当按一下按键然后松开&#xff0c;MOS管导通&#xff0c;VOUT等于电源电压; 当再次按一下按键然后松开&#xff0c;MOS管关闭&#xff0c;VOUT等于0; 下面来分析一下这个电路的工作原理。上电后&#xff0c;输入电压通过R1和R2给电容充电&#xff0c;最…

微软GraphRAG +本地模型+Gradio 简单测试笔记

安装 pip install graphragmkdir -p ./ragtest/input#将文档拷贝至 ./ragtest/input/ 下python -m graphrag.index --init --root ./ragtest修改settings.yaml encoding_model: cl100k_base skip_workflows: [] llm:api_key: ${GRAPHRAG_API_KEY}type: openai_chat # or azu…