1、RDB持久化
数据库状态:服务器中非空数据库以及他们的键值对统称为数据库状态。
RDB持久化既可以手动也可以根据服务器配置定期执行。将某个时间点上的数据库状态保存到一个RDB文件中(二进制文件)。通过该文件可以还原生成RDB文件时的数据库文件。
1.1RDB文件的创建与载入
生成RDB文件的命令:SAVE\BGSAVE。两者区别:
RDB文件的载入工作是在服务器启动的时候自动执行的,所以Redis没有专门载入RDB文件的命令,只要Redis服务器在启动时检测到RDB文件的存在就会自动载入RDB文件。
1.1.1SAVE命令执行时服务器的状态
1.1.2BGSAVE命令执行时服务器的状态
1.1.3RDB文件载入时的服务器状态
服务器在载入RDB文件期间,会一直处于阻塞状态,知道载入工作完成为止
1.2自动间隔性保存
1.2.1设置保存条件
1.2.2dirty计数器和last save属性
1.2.3检查保存条件是否满足
1.3RDB文件结构
REDIS长度为5字节,保存着REDIS这五个字符,通过这五个支付,程序在载入文件时可以快速检查所载入的文件是否RDB文件。
db_version长度为4字节,它的值是一个字符串表示的整数,记录了RDB文件的版本号
databases包含着0个或者任意多个数据库,以及各个数据库中的键值对数据:服务器数据库状态为空(所有数据库都是空的),那么这部分也是空,长度为0;如果数据库状态为非空(至少有一个数据库非空),那么这个部分也为非空。
EOF长度为1字节,标志着RDB文件正文内容结束。
check_num是一个8字节长的无符号整数,是一个校验和。
1.3.1databases部分
1.3.2key_value_pairs部分
1.3.3value编码
1.字符串对象:
2.列表对象:
3.集合对象:
4.哈希表对象:
5.有序集合对象
6.INSET编码的集合
7.ZIPLIST编码的列表、哈希表或者有序集合
1.4分析RDB文件
1.4.1不包含任何键值对的RDB文件
1.4.2包含字符串的RDB文件
1.4.3包含带有过期时间的字符串键的RDB文件
1.4.4包含一个集合键的RDB文件
2.AOF持久化
2.1AOF持久化的实现
AOF持久化功能的实现可以分为命令追加、文件写入、文件同步三个步骤
2.1.1命令追加
2.1.2AOF文件的写入与同步
2.3AOF重写
2.3.1AOF文件重写的实现
首先从数据库中读取键现在的值,然后用一条命令去记录键值对,代替之前记录这个键值对的多条命令。
2.3.2AOF后台重写