RDB持久化①RDB文件的创建与载入

146 阅读2分钟

这是我参与11月更文挑战的第13天,活动详情查看:2021最后一次更文挑战

RDB持久化

redis提供RDB持久化功能,将Redis在内存中的数据库状态保存到磁盘里面,避免数据意外丢失

RDB持久化既可以手动执行,也可以根据服务器配置选项定期执行,将某个时间点上的数据库状态保存到一个RDB文件中。

RDB持久化功能所生成的RDB文件是一个经过压缩的二进制文件,通过该文件可以还原成RDB文件时的数据库状态

RDB文件的创建与载入

有两个Redis命令可以用于生成RDB文件,save和bgsave

save命令会阻塞Redis服务器进程,直到RDB文件创建完毕为止,服务器进程阻塞期间,服务器不能处理任何命令请求

BGSAVE命令会派生出一个子进程,然后由子进程负责创建RDB文件,服务器进程继续处理命令请求

创建RDB文件的实际工作由rdb.c的rdbSave函数完成,rdb文件的载入工作是在非服务器启动时自动执行的,所以redis并没有专门用于载入RDB文件的命令,只要Redis服务器在启动时检测到RDB文件存在,它就会自动载入RDB文件。

AOF文件的更新频率通常比RDB文件的更新频率高,如果服务器开启了AOF持久化功能,那么服务器会优先使用AOF文件来还原数据库状态,AOF持久化功能关闭的时候,服务器才会使用RDB文件还原数据库状态

服务器载入RDB文件期间,会一直处于阻塞状态,直到载入工作完成为止。

BGSAVE命令执行期间:

SAVE命令会被服务器拒绝,服务器禁止SAVE和BGSAVE同时执行是为了避免父进程和子进程同时执行rdbSave调用,防止产生竞争

BGSAVE命令也会被服务器拒绝,因为执行两个BGSAVE命令也会产生竞争

BGREWRITEAOP和BGSAVE也不能同时执行:

BGSAVE正在执行,BGREWRITEAOP就会在BGSAVE命令执行完毕后执行

BGREWRITEAOP正在执行,BGSAVE命令会被服务器拒绝。