《Redis设计与实现》读书笔记-第二部分:单机数据库的实现-2:持久化

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后台重写 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值