《Redis设计与实现》学习笔记(八) RDB持久化
一. RDB文件的创建与写入
- 两个redis命令可以生成RDB,一个是
SAVE
一个是BGSAVE
,SAVE会阻塞进程,BGSAVE会生成子线程执行,不会阻塞进程,且两者不能同时运行 - RDB是默认持久化方式,如果开启了AOF
优先AOF
二. 自动间隔性保存
- 通过save选项可以设置多个保存条件
- Dirty计数器:上次SAVE或BGSAVE之后对数据库进行修改的次数
- Lastsave是上次修改的时间戳
三. RDB文件结构
Databases:可以保存任意多的非空数据库,且每个数据库都可以保存为selectdb, db_number, key_value_pairs三个部分
四. 分析RDB文件
- 不包含任何键值对的RDB文件:od命令
od -c dump.rdb
可以打印RDB文件,这时文件仅有四个部分组成:- “REDIS”字符串
- 四个字节的版本号db_version
- EOF常量
- 八个字节的校验和
- 包含字符串的RDB文件:由三个部分组成:
- 一个字节长的“SELECTDB”
- 1或2或5字节长的数据库号码db_number
- 一个或多个键值对key_value_pairs
- 包含带有过期时间的RDB文件:多了
- 一个字节长的EXPIRETIME_MS
- 一个八字节的过期时间