1. redis为什么需要持久化?
因为redis是内存数据库,它将数据存储在内存里,如果服务器进程退出,内存中的数据也会丢失
2. 生成rdb文件的两个命令
save: save命令会阻塞redis服务器进程,直到rdb文件创建完毕,在服务器进程阻塞期间,服务器不能处理任何命令请求
bgsave: bgsave会派生一个子进程,在子进程里创建rdb文件,服务器主进程会继续处理命令
3. rdb文件的载入
rdb文件的载入没有专门的命令,只有在服务器启动时自动执行
3.1. aof文件的更新频率一般比rdb文件的频率快,所以:
a. 如果服务器开启了aof功能,会优先使用aof文件来还原数据库状态
b. 当aof持久化功能处于关闭时,才会使用rdb文件
4. 持久化服务器的状态
a. 当执行save命令时,redis会被阻塞,当save命令正在执行时,所有客户端的命令都会被拒绝
b. 当执行bgsave时, 当客户端发送save命令时会被拒绝,发送bgsave命令也会被拒绝
5. 设置自动执行bgsave命令
save 900 1
save 300 10
save 60 100000
只要有一个条件被满足,bgsave命令就会被执行
如: save 900 1 代表服务器在900秒内,对数据库进行了至少1次的修改就会自动执行bgsave
5.1 实现原理
a.
struct redisServer {
//数组,记录save配置的条件
struct saveparam *saveparams;
}
b.
struct redisServer{
//计数器,成功执行一个数据库修改命令的次数
long long dirty;
//上次执行保存的时间
time_t lastsave;
}
c. 定时执行任务,检查save的选项是否被满足,如果满足就执行bgsave
6. rdb保存的是键值对