Redis是内存数据库,如果不将内存中的数据库状态保存到磁盘,name一旦服务器进程退出,服务器中的数据库状态也会消失。所以Redis提供了持久化功能。
RDB(Redis DataBase)
什么是RDB
在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是行话讲的Snapshot快照,它恢复时是将快照文件直接读到内存里。
Redis会单独创建( fork) -一个子进程来进行持久化,会先将数据写入到-一个临时文件中,待持久化过程都结束了,再用这个临时文件替换.上次持久化好的文件。整个过程中,主进程是不进行任何I0操作的。这就确保了极高的性能。如果需要进行大规模数据的恢复,且对于数据恢复的完整性不是非常敏感,那RDB方式要比AOF方式更加的高效。RDB的缺点是最后- -次持久化后的数据可能丢
失。
rdb保存的文件是dump.rdb
触发机制
- save的规则满足的情况下,会自动触发rdb规则
- 执行flushall命令,也会触发rdb规则
- 退出redis也会产生rdb文件
恢复
- 只需要将rdb文件房子redis启动目录就可以,redis启动时候会自动检查dump.rdb并恢复其中的数据。
- 查看rdb文件存在的位置
127.0.0.1:6379> config get dir
1) "dir"
2) "/data"
优点:
1、 适合大规模的数据恢复
2、 对数据的完整性要求不高
缺点:
1、 需要一定的时间间隔进行操作。如果redis意外宕机了,这个最后一次修改的数据就没有了
2、 fork进程的时候会占用一定的内存空间
AOF(Append Only File)
将我们的所有命令都记录下来,恢复的时候全部在执行一遍!
是什么
以日志的形式来记录每个写操作,将Redis执行过的所有指令记录下来(读操作不记录) ,只许追加文件但不可以改写文件, redis启动之初会读取该文件重新构建数据,换言之, redis重启的话就根据日志文件的内容将写指令从前到后执行一次以完成数据的恢复工作。
aof保存的是appendonly.aof
优点:
1、 每一次修改都同步,文件的完整性会更好
2、 每秒同步一次,坑会丢失一秒的数据
3、 从不同步,效率最高
缺点:
1、相对于数据文件来说,aof远远大于rdb,修复速度也比rdb慢
2、aof运行效率也要比rdb慢,所以我们redis默认的配置就是rdb持久化