1、RDB持久化

js读取redis数据 redis怎么读取rdb中的数据_redis

 

数据库状态:服务器中非空数据库以及他们的键值对统称为数据库状态。

js读取redis数据 redis怎么读取rdb中的数据_js读取redis数据_02

RDB持久化既可以手动也可以根据服务器配置定期执行。将某个时间点上的数据库状态保存到一个RDB文件中(二进制文件)。通过该文件可以还原生成RDB文件时的数据库文件。

js读取redis数据 redis怎么读取rdb中的数据_redis_03

1.1RDB文件的创建与载入

生成RDB文件的命令:SAVE\BGSAVE。两者区别:

js读取redis数据 redis怎么读取rdb中的数据_js读取redis数据_04

RDB文件的载入工作是在服务器启动的时候自动执行的,所以Redis没有专门载入RDB文件的命令,只要Redis服务器在启动时检测到RDB文件的存在就会自动载入RDB文件。 

js读取redis数据 redis怎么读取rdb中的数据_持久化_05

1.1.1SAVE命令执行时服务器的状态

js读取redis数据 redis怎么读取rdb中的数据_js读取redis数据_06

1.1.2BGSAVE命令执行时服务器的状态 

js读取redis数据 redis怎么读取rdb中的数据_持久化_07

1.1.3RDB文件载入时的服务器状态

服务器在载入RDB文件期间,会一直处于阻塞状态,知道载入工作完成为止

1.2自动间隔性保存

js读取redis数据 redis怎么读取rdb中的数据_服务器_08

1.2.1设置保存条件

js读取redis数据 redis怎么读取rdb中的数据_服务器_09

1.2.2dirty计数器和last save属性

js读取redis数据 redis怎么读取rdb中的数据_服务器_10

1.2.3检查保存条件是否满足 

js读取redis数据 redis怎么读取rdb中的数据_服务器_11

1.3RDB文件结构 

js读取redis数据 redis怎么读取rdb中的数据_服务器_12

REDIS长度为5字节,保存着REDIS这五个字符,通过这五个支付,程序在载入文件时可以快速检查所载入的文件是否RDB文件。

db_version长度为4字节,它的值是一个字符串表示的整数,记录了RDB文件的版本号

databases包含着0个或者任意多个数据库,以及各个数据库中的键值对数据:服务器数据库状态为空(所有数据库都是空的),那么这部分也是空,长度为0;如果数据库状态为非空(至少有一个数据库非空),那么这个部分也为非空。

EOF长度为1字节,标志着RDB文件正文内容结束。

check_num是一个8字节长的无符号整数,是一个校验和。

1.3.1databases部分

js读取redis数据 redis怎么读取rdb中的数据_持久化_13

js读取redis数据 redis怎么读取rdb中的数据_数据库_14

 1.3.2key_value_pairs部分

js读取redis数据 redis怎么读取rdb中的数据_持久化_15

js读取redis数据 redis怎么读取rdb中的数据_服务器_16

js读取redis数据 redis怎么读取rdb中的数据_持久化_17

1.3.3value编码

1.字符串对象: 

js读取redis数据 redis怎么读取rdb中的数据_redis_18

js读取redis数据 redis怎么读取rdb中的数据_数据库_19

2.列表对象:

js读取redis数据 redis怎么读取rdb中的数据_redis_20

3.集合对象:

js读取redis数据 redis怎么读取rdb中的数据_服务器_21

4.哈希表对象: 

js读取redis数据 redis怎么读取rdb中的数据_js读取redis数据_22

 

5.有序集合对象

 

js读取redis数据 redis怎么读取rdb中的数据_redis_23

 

js读取redis数据 redis怎么读取rdb中的数据_持久化_24

6.INSET编码的集合

js读取redis数据 redis怎么读取rdb中的数据_redis_25

7.ZIPLIST编码的列表、哈希表或者有序集合 

js读取redis数据 redis怎么读取rdb中的数据_持久化_26

1.4分析RDB文件 

1.4.1不包含任何键值对的RDB文件

js读取redis数据 redis怎么读取rdb中的数据_js读取redis数据_27

1.4.2包含字符串的RDB文件 

js读取redis数据 redis怎么读取rdb中的数据_js读取redis数据_28

1.4.3包含带有过期时间的字符串键的RDB文件 

js读取redis数据 redis怎么读取rdb中的数据_持久化_29

1.4.4包含一个集合键的RDB文件 

js读取redis数据 redis怎么读取rdb中的数据_持久化_30

 

2.AOF持久化

js读取redis数据 redis怎么读取rdb中的数据_持久化_31

 

js读取redis数据 redis怎么读取rdb中的数据_持久化_32

 

js读取redis数据 redis怎么读取rdb中的数据_数据库_33

 2.1AOF持久化的实现

AOF持久化功能的实现可以分为命令追加、文件写入、文件同步三个步骤

2.1.1命令追加

 

js读取redis数据 redis怎么读取rdb中的数据_服务器_34

 2.1.2AOF文件的写入与同步

js读取redis数据 redis怎么读取rdb中的数据_数据库_35

 

js读取redis数据 redis怎么读取rdb中的数据_redis_36

2.3AOF重写

js读取redis数据 redis怎么读取rdb中的数据_redis_37

 2.3.1AOF文件重写的实现

首先从数据库中读取键现在的值,然后用一条命令去记录键值对,代替之前记录这个键值对的多条命令。

js读取redis数据 redis怎么读取rdb中的数据_数据库_38

js读取redis数据 redis怎么读取rdb中的数据_redis_39

 

js读取redis数据 redis怎么读取rdb中的数据_持久化_40

2.3.2AOF后台重写 

 

js读取redis数据 redis怎么读取rdb中的数据_js读取redis数据_41

 

js读取redis数据 redis怎么读取rdb中的数据_持久化_42

 

js读取redis数据 redis怎么读取rdb中的数据_redis_43

 

js读取redis数据 redis怎么读取rdb中的数据_持久化_44