2021-06-19 08:43:05
RDB 是 Redis 默认的持久化方案。在指定的时间间隔内,执行指定次数的写操作,则会将内存中的数据写入到磁盘中,即在指定目录下生成一个 dump.rdb 文件。Redis 重启会通过加载 dump.rdb 文件恢复数据。

save <seconds> <changes>:save "" save 900 1 save 300 10 save 60 10000。解说:save <指定时间间隔> <执行指定次数更新操作>,满足条件就将内存中的数据同步到硬盘中。官方出厂配置默认是 900 秒内有 1 个更改,300 秒内有 10 个更改以及 60 秒内有 10000 个更改,则将内存中的数据快照写入磁盘。若不想用 RDB 方案,可以把 save "" 的注释打开,下面三个注释。
将 dump.rdb 文件拷贝到 redis 的安装目录的 bin 目录下,重启 redis 服务即可。在实际开发中,一般会考虑到物理机硬盘损坏情况,选择备份 dump.rdb。
优缺点适合大规模的数据恢复。
如果业务对数据完整性和一致性要求不高,RDB 是很好的选择。
数据的完整性和一致性不高,因为 RDB 可能在最后一次备份时宕机了。
备份时占用内存,因为 Redis 在备份时会独立创建一个子进程,将数据写入到一个临时文件(此时内存中的数据是原来的两倍哦),最后再将临时文件替换之前的备份文件。所以 Redis 的持久化和数据的恢复要选择在夜深人静的时候执行是比较合理的。
注意点:SHUTDOWN 和 FLUSHALL 命令都会触发 RDB 快照,这是一个坑,请大家注意。
其他命令:
AOF:Redis 默认不开启。它的出现是为了弥补 RDB 的不足(数据的不一致性),所以它采用日志的形式来记录每个写操作,并追加到文件中。Redis 重启的会根据日志文件的内容将写指令从前到后执行一次以完成数据的恢复工作。
配置文件相关# appendfsync always appendfsync everysec # appendfsync no。解说:
always:同步持久化,每次发生数据变化会立刻写入到磁盘中。性能较差当数据完整性比较好(慢,安全)。
everysec:出厂默认推荐,每秒异步记录一次(默认值)。
no:不同步。
auto-aof-rewrite-percentage 100 auto-aof-rewrite-min-size 64mb。解说:当 AOF 文件大小是上次 rewrite 后大小的一倍且文件大于 64M 时触发。一般都设置为 3G,64M 太小了。
根据配置文件触发,可以是每次执行触发,可以是每秒触发,可以不同步。
根据 AOF 文件恢复数据正常情况下,将 appendonly.aof 文件拷贝到 redis 的安装目录的 bin 目录下,重启 redis 服务即可。但在实际开发中,可能因为某些原因导致 appendonly.aof 文件格式异常,从而导致数据还原失败,可以通过命令 redis-check-aof --fix appendonly.aof 进行修复。
AOF 的重写机制前面也说到了,AOF 的工作原理是将写操作追加到文件中,文件的冗余内容会越来越多。所以聪明的 Redis 新增了重写机制。当 AOF 文件的大小超过所设定的阈值时,Redis 就会对 AOF 文件的内容压缩。
补充点:aof 的校验是通过 redis-check-aof 文件,那么 rdb 的校验是不是可以通过 redis-check-rdb 文件呢???