redis持久化RDB与AOF的对比
redis持久化RDB与AOF的对比
Redis提供了两种主要的持久化机制:RDB(Redis Database)和AOF(Append Only File)。
RDB持久化
RDB是通过创建数据库状态的快照来实现持久化的。在指定的时间间隔内,如果指定数量的键被修改,Redis就会创建一个快照并保存到磁盘上。这个快照可以手动触发,也可以根据配置文件中设置的规则自动触发。RDB文件是二进制格式,通常较小,恢复速度快。
在Redis中,RDB持久化可以通过两种不同的方式触发:
- 手动触发:使用
SAVE
或BGSAVE
命令立即创建快照。 - 自动触发:根据
配置文件中
save
指令指定的规则自动进行。
下面是使用redis-cli
命令行工具来演示RDB持久化的命令:
手动触发RDB持久化
使用SAVE
命令(会阻塞Redis处理其他命令,直到快照完成):
127.0.0.1:679> SAVE
OK
使用BGSAVE
命令(会创建一个子进程来处理快照,不阻塞主进程):
127.0.0.1:679> BGSAVE
Background saving started
注意:BGSAVE
命令的输出不会立即显示“OK”,而是告诉你快照操作已经在后台开始。
自动触发RDB持久化
在配置文件中,可以通过设置如下规则来自动触发RDB持久化:
save 900 1 # 如果至少有1个键被改变,则每900秒保存一次
save 00 10 # 如果至少有10个键被改变,则每00秒保存一次
save 60 10000 # 如果至少有10000个键被改变,则每60秒保存一次
这些规则意味着,根据键的修改次数和时间间隔,Redis会自动执行BGSAVE
来创建数据快照。
要应用配置文件中的持久化设置,需要重启Redis服务器或者使用COFIG REWRITE命令来重写配置(如果配置文件中设置了可覆盖选项):
127.0.0.1:679> COFIG REWRITE OK COFIG REWRITE命令将当前的配置写入到配置文件中,不重启Redis服务。
查看当前RDB持久化配置
可以使用COFIG GET
命令查看当前的RDB持久化配置:
127.0.0.1:679> COFIG GET save
1) "save"
2) 1) "900"
2) "1"
) 1) "00"
2) "10"
4) 1) "60"
2) "10000"
这表示当前的自动快照规则与上面提到的配置相符。
RDB持久化的快照文件默认命名为dump.rdb
,存储在Redis服务器的工作目录中。这个二进制文件可以在Redis重启时被加载,以恢复数据。由于RDB文件是经过压缩的,它通常体积较小,恢复速度较快。
AOF持久化
AOF持久化记录了服务器接收到的每一个写操作命令,并将这些命令追加到文件的末尾。在Redis重启时,它会重放这些命令来重建原始数据。AOF文件是文本格式,可以提供更好的持久性保证,但是文件大小通常会比RDB大,且恢复速度慢。
AOF持久化在Redis中通过记录每个写操作命令来实现。以下是演示如何在Redis中启用AOF持久化、如何查看当前AOF状态以及如何执行AOF重写的命令:
启用AOF持久化
要启用AOF持久化,你需要在配置文件中设置
appendonly
为yes
。你也可以使用COFIG SET
命令动态地修改此配置:
127.0.0.1:679> COFIG SET appendonly yes
OK
查看当前AOF持久化配置
要查看当前的AOF持久化配置,可以使用COFIG GET
命令:
127.0.0.1:679> COFIG GET appendonly
1) "appendonly"
2) "yes"
AOF文件同步策略
Redis提供了几种不同的AOF文件同步策略,可以通过appendfsync
配置项设置。以下是可用的选项:
always
:每次写操作后都同步,数据安全性最高,但可能会影响性能。everysec
:每秒同步一次,这是默认设置,提供性能和数据安全性的平衡。no
:让系统自行决定何时同步,可能会丢数据,但性能最好。
查看当前的AOF同步策略:
代码语言:javascript代码运行次数:0运行复制127.0.0.1:679> COFIG GET appendfsync
1) "appendfsync"
2) "everysec"
修改AOF同步策略:
代码语言:javascript代码运行次数:0运行复制127.0.0.1:679> COFIG SET appendfsync always
OK
执行AOF重写
AOF重写(AOF rewrite)是优化AOF文件的过程,它会创建一个新的AOF文件,其中包含重建当前数据集所需的最少命令集合。这可以减少AOF文件的大小并提高恢复速度。
要触发AOF重写,可以使用BGREWRITEAOF
命令:
127.0.0.1:679> BGREWRITEAOF
Background append only file rewriting started
请注意,和BGSAVE
类似,BGREWRITEAOF
也是在后台执行,不会阻塞Redis服务器。
查看AOF重写进度
Redis提供了IFO
命令,通过它可以查看AOF重写的进度:
127.0.0.1:679> IFO Persistence
# Persistence
aof_rewrite_in_progress:0
aof_last_rewrite_time_sec:162687198
aof_current_size:56924
aof_base_size:56924
aof_pending_rewrite:0
aof_buffer_length:0
aof_rewrite_buffer_length:0
...
在输出中,aof_rewrite_in_progress
字段将显示AOF重写是否正在进行(0表示没有,1表示是)。
RDB与AOF的区别
特性 | RDB | AOF |
---|---|---|
持久化方式 | 快照(Snapshot) | 日志(Log) |
文件格式 | 二进制(Binary) | 文本(Text) |
文件大小 | 通常较小(Compact) | 通常较大(Bulkier) |
启动加载速度 | 快(Faster) | 慢(Slower) |
数据安全性 | 可能丢失数据(取决于快照频率) | 高安全性(除非配置了不同步磁盘) |
磁盘I/O | 快照创建时较高(Snapshot creation can be I/O intensive) | 持续较低(Lower I/O as commands are appended) |
配置 | save <seconds> <changes> | appendonly yes 和 appendfsync 选项 |
适用场景 | 数据不频繁更新,对数据完整性要求不高的场景 | 数据更新频繁,对数据完整性要求高的场景 |
恢复速度 | 快速(Quick to restore) | 慢(Slower to restore) |
缺点 | 可能会丢失数据 | 文件可能会变得很大,影响性能 |
混合持久化 | Redis 4.0+ 支持RDB和AOF的混合持久化,提高数据安全性的同时加快启动速度 | Redis 4.0+ 支持RDB和AOF的混合持久化,提高数据安全性的同时加快启动速度 |
#感谢您对电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格的认可,转载请说明来源于"电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格
上一篇:Tomcat安装和配置
下一篇:什么是CMS系统
推荐阅读
留言与评论(共有 13 条评论) |
本站网友 封闭式问题 | 10分钟前 发表 |
679> SAVE OK使用BGSAVE命令(会创建一个子进程来处理快照 | |
本站网友 抑郁症案例分析 | 17分钟前 发表 |
根据键的修改次数和时间间隔 | |
本站网友 foster | 20分钟前 发表 |
不重启Redis服务 | |
本站网友 友商网 | 27分钟前 发表 |
提供性能和数据安全性的平衡 | |
本站网友 澳洲大选 | 27分钟前 发表 |
679> BGREWRITEAOF Background append only file rewriting started请注意 | |
本站网友 女性阴部真实照片 | 30分钟前 发表 |
可能会丢数据 | |
本站网友 白河漂流 | 8分钟前 发表 |
下面是使用redis-cli命令行工具来演示RDB持久化的命令:手动触发RDB持久化使用SAVE命令(会阻塞Redis处理其他命令 | |
本站网友 美妆电商 | 20分钟前 发表 |
如果指定数量的键被修改 | |
本站网友 驴肉的功效与作用 | 3分钟前 发表 |
也可以根据配置文件中设置的规则自动触发 | |
本站网友 苏州建设网 | 23分钟前 发表 |
AOF持久化AOF持久化记录了服务器接收到的每一个写操作命令 | |
本站网友 白果是什么 | 10分钟前 发表 |
以下是可用的选项:always:每次写操作后都同步 | |
本站网友 梦见被狗咬手指 | 1分钟前 发表 |
它会创建一个新的AOF文件 |