Redis是内存数据库,一旦服务器进程退出,服务器中的数据也会丢失。因此需要持久化功能将数据存储到磁盘中,即使重启了保证数据不丢失。
Redis的持久化方式有两种:RDB、AOF。
AOF文件的更新频率通常比RDB文件的更新频率高,所以如果服务器开启了AOF持久化功能,那么服务器会优先使用AOF文件来还原数据库状态。只有在AOF关闭,服务器才会使用RDB文件来还原数据库状态。
RDB 持久化
RDB 持久化功能主要是生成一个经过压缩的二进制文件(RDB文件)来保存数据,然后在需要还原的时候通过读取RDB文件来恢复数据库状态。
创建与载入
生成RDB文件有两个Redis命令:SAVE、BGSAVE。
载入时机:RDB文件的载入工作是在服务器启动时自动执行的,所以Redis并没有专门用于载入RDB文件的命令,只要Redis服务器在启动时检测到RDB文件存在,就会自动载入。
服务器在载入RDB文件期间,会一直处于阻塞状态,直到载入工作完成为止。
SAVE
SAVE 命令会阻塞 Redis 服务器进程,直到RDB文件创建完毕,在阻塞期间,服务器不能处理任何命令请求。
def SAVE():
rdbSave()
BGSAVE
BGSAVE 命令不阻塞父进程,会fork一个子进程,然后由子进程负责创建RDB文件,父进程继续处理命令请求。
def BGSAVE():
pid = fork() // 创建子进程
if pid