什么是RDB?
RDB:Redis Database(Redis数据库),是Redis的一种数据持久化机制
注:可通过config get dir命令获取rdb文件目录
如何触发RDB?
1.主动触发:执行save或bgsave命令
2.自动触发:满足配置文件中设置的自动触发RDB机制的条件时,执行bgsave命令

3.执行shutdown命令时
可选择nosave或save,选择save则执行bgsave命令

4.执行flushall命令时
执行flushall命令时,若不存在rdb文件,则创建空的rdb文件,否则清空rdb文件(flushall不仅清空rdb文件,也清空内存中的数据)
5.执行debug reload命令时
debug reload命令可令主节点安全重启,安全重启不会改变runid(避免不必要的全量复制)与offset(保证正确进行增量复制)
debug reload步骤:
1.执行bgsave命令 2.清空内存数据 3.重新从rdb文件中读取数据
需要注意的是:从rdb文件中读取数据的过程会导致主节点阻塞,此为安全重启的代价
6.进行主从复制时
主从复制步骤:
1.从节点发送同步请求至主节点 2.主节点接收到请求后: 1)立即执行 bgsave 命令进行持久化 并使用缓冲区记录此刻开始的写命令 2)持久化完成后将rdb文件与缓冲区数据发送给从节点 3.从节点接收到rdb文件后: 1)清空自身数据 2)加载rdb文件与缓冲区数据
save命令与bgsave命令的区别
save: 主进程执行持久化,此时客户端的请求将被阻塞,直至持久化完成
bgsave:fork子进程执行持久化,主进程继续处理客户端的请求

RDB的优缺点
优势:
劣势:
RDB持久化机制适合在对数据完整性要求不高的场合使用