Redis是基于内存实现的数据库,一旦服务退出内存所有数据都消失。如果想在服务器重启时能够加载上次内存的数据,需要进行数据持久化到磁盘中。
RDB持久化的是内存中的数据内容。优先级低于AOF模式。
SAVE命令会阻塞Redis服务进程,直到RDB文件创建完毕为止,阻塞阶段不对外提供服务。
BGSAVE通过创建一个子进程,由子进程完成RDB文件创建,服务器能够正常对外提供服务。
自动间隔保存是通过BGSAVE命令实现的。当满足下列条件
save 1200 1 #1200秒之内,对数据库进行至少1次修改
save 600 5 #600秒之内,对数据库进行至少5次修改
save 60 100 #60秒之内,对数据库进行至少100次修改
会判断是否开启AOF持久化功能,如果开启则采用AOF文件恢复数据,否则采用RDB文件恢复数据。
AOF持久化的是Redis服务器所执行的命令记录。
AOF持久化实现:命令追加、文件写入、文件同步。
立即写入并同步:将aof_buf缓冲区的内容写入并同步到AOF文件。
间隔写入并同步:将aof_buf缓冲区的内容写入到AOF文件,如果上次同步AOF文件的时间间隔超过1秒,那么再次进行AOF文件同步。
写入不同步:将内容写入到AOF文件,但合同同步文件将由操作系统来决定,
操作系统执行文件写操作,会将写入内容放入到一个缓冲区中,当到达一定时间或是超过缓冲区时,才会将缓存区内容同步到文件,即磁盘中
用来解决命令不断执行,导致AOF不断膨胀问题。
AOF通过重写来合并命令,并丢弃一些已删除的命令。