个人简单理解:
ROB快照是:每次触发保存是将所有内存快照到一个新的rdb文件里面;
有2种方式:save 和 bgsave
save:同步 执行,阻塞客户端redis命令 知道保存完成
bgsave:异步执行,需要fork字进程,消耗内存。但是不阻塞客户端redis命令
AOF: 将修改的每一条指令记录转换为RESP指令写入到.aof文件中(先写到 os 缓存, 一段时间后写入磁盘)。
AOF重写: aof文件在一段时间后存在一些无用的指令,所以aof会定期根据内存中最新 的数据生成AOF文件
RDB快照(snapshot)
AOF
你可以配置 Redis 多久才将数据 fsync 到磁盘一次。 有三个选项:
1 appendfsync always:每次有新命令追加到 AOF 文件时就执行一次 fsync ,非常慢,也非常安全。
2 appendfsync everysec:每秒 fsync 一次,足够快,并且在故障时只会丢失 1 秒钟的数据。
3 appendfsync no:从不 fsync ,将数据交给操作系统来处理。更快,也更不安全的选择。
AOF重写
RDB和AOF 的选择
Redis 4.0 混合持久化