一、redis持久化

1、RDB
RDB持久性以指定的时间间隔执行数据集的时间点快照
也就是说在一定的时间间隔内,将某一时刻的数据和状态以文件的形式写到磁盘上,这个快照文件交dump.rdb
Redis6更新策略

Redis7更新策略

RDB手动触发

5秒2次修改



RDB手动触发
save:优先级高,执行该命令时其他进程都会停下来等这个命令执行完,因此在此期间redis对外缓存功能失效,很少用
bgsave:在执行该命令的时候,redis产生一个fork,相当于复制了一个父进程,由此来异步保存RDB
lastsave //查看上一次保存的时间戳,在linux下查看日期


优缺点

RDB修复命令

哪些操作会触发RDB快照
- 配置文件中默认的快照配置
- 手动 save/bgsave 命令
- 执行flush / flushdb 命令也会产生 dump.rdb 文件,但里面是空的,无意义
- 执行 shutdown 且没有设置开启 AOF 持久化
- 主从复制时,主节点自动触发
如何禁用快照
动态所有停止 RDB 保存规则的方法: redis-cli config set save “”
快照禁用

RDB优化参数





小结

2、AOF
只记录写操作


AOF 持久化工作流程

AOF 缓冲区三种写回策略
- always 同步写回,每个写命令执行完立刻同步地将日志写回磁盘
- everysec (默认)每秒写回,每个写命令执行完,只是先把日志写到AOF缓冲区,每隔1s把缓存区地数据写入磁盘
- no操作系统控制写回,只是将日志先写到AOF文件的内存缓冲区,由操作系统决定何时将缓冲区内容写回磁盘

AOF功能配置







AOF正常恢复
AOF正常恢复是写在incr文件

AOF异常恢复

比如,模拟incr文件错误

结果:当AOF文件破损后,redis启动都1启动不了

AOF文件异常修复
//命令:
redis-check-aof --fix appendonly.aof.1.incr.aof

AOF的优缺点


AOF重写机制

自动配置
- 满足配置文件中的选项后,Redis会记录上次重写时地AOF大小
- 默认配置是当AOF文件大小是上次rewrite后大小的一倍且文件大于64M时


手动配置 - 客户端向服务器发送 bgrewriteaof 命令

小结


3、RDB+AOF混合
AOF默认是关闭的,当两者共存时,AOF的优先级高

同时开启两种持久化方式
- 当redis 重启时候会优先载入AOF文件来恢复原始的数据,因为在通常情况下AOF文件保存的数据集要比RDB文件保存的数据集要完整
- RDB的数据不实时,同时使用两者时服务器重启也只会找AOF文件。
- 那要不要只使用AOF呢
- 安特雷兹建议不要
- 因为RDB更适合用于备份数据库(AOF不断变化不好备份),留着AOF作为一个万一的手段

- 那要不要只使用AOF呢
4、纯缓存模式
同时关闭RDB + AOF
- save “”
- 禁用rdb
- 禁用db持久化模式下,我们仍然可以使用命令save、bgsave生成rdb文件
- appendonly no
- 禁用aof
- 禁用aof持久化模式下,我们仍然可以使用命令 bgrewriteaof生成aof文件



















