RDB持久化既可以手动执行,也可以根据服务器配置选项定期执行,该功能可以将某个时间点上的数据库状态(数据库信息和所有数据库中的键值对)保存到一个RDB文件中
RDB文件是一个经过压缩的二进制文件
可以将数据库状态保存为RDB文件,也可以通过读取RDB文件,加载数据库状态。
一、RDB文件的创建与载入
RDB文件的创建可以用 save
或者 bgsave
两种方式,前者是将服务器当前的任务阻塞然后保存数据库状态,后者则是等服务器将当前任务完成之后再保存数据库状态。
RDB文件的载入是 服务器启动的时候自动执行的,服务器在启动的时候如果发现有RDB文件,就会将其载入。
[注] AOF文件的更新频率比RDB文件的更新频率高,因此
(1)若服务器开启了AOF持久化功能,那么会优先使用AOF文件来加载数据库状态
(2)若没有开启AOF持久化功能,服务器才会用AOF文件加载数据库状态
RDB持久化原理:通过bgsave命令触发,然后父进程执行fork操作创建子进程,子进程创建RDB文件,根据父进程内存生成临时快照文件,完成后对原有文件进行原子替换(定时一次性将所有数据进行快照生成一份副本存储在硬盘中)
优点:是一个紧凑压缩的二进制文件,Redis加载RDB恢复数据远远快于AOF的方式。
缺点:由于每次生成RDB开销较大,非实时持久化