论redis的rdb和aof持久化

2017-10-02  本文已影响0人  舒小贱

因为 Redis 是内存数据库,数据库状态存储在内存里面,如果不想办法将存储在内存中的数据库状态保存到磁盘,那么一旦服务器退出,服务器中的数据库状态也会消失.Redis 提供了 RDB 和aof两种可选的持久化功能,

一:rdb持久化

rdb持久化功能可以将 Redis 在内存中的数据库状态保存到磁盘里面,避免数据意外丢失.Redis 持久化会将数据库状态保存到一个 RDB 文件中,相当于保存一个快照。可以手动执行,也可以根据服务器配置选项定期执行。

RDB 文件的创建
有两个命令可以生成rdb文件:save和bgsave。

SAVE 命令会阻塞服务器进程,知道 RDB 文件创建完为止,在服务器阻塞期间,服务器不能处理任何命令请求.
BGSAVA 会派生出一个子进程,然后又后台子进程负责创建 RDB 文件,服务器父进程继续处理命令请求.

RDB 文件的载入
RDB 文件的载入是在服务器启动时自动执行的, Redis 没有专门用于载入 RDB 文件的命令.
在服务器的启动日志里,可以看到以下内容:

67568:M 03 Apr 13:43:16.481 # Server started, Redis version 3.0.7
67568:M 03 Apr 13:43:16.482 * DB loaded from disk: 0.001 seconds
67568:M 03 Apr 13:43:16.482 * The server is now ready to accept connections on port 6379

另外, 因为 AOF 文件的保存频率通常要高于 RDB 文件保存的频率, 所以一般来说, AOF 文件中的数据会比 RDB 文件中的数据要新。

因此, 如果服务器在启动时, 打开了 AOF 功能, 那么程序优先使用 AOF 文件来还原数据。 只有在 AOF 功能未打开的情况下, Redis 才会使用 RDB 文件来还原数据。

自动间隔保存
因为 SAVE 命令会阻塞服务器,而BGSAVE 命令不会,所以 Redis 允许用户通过设置 服务器配置的 save选项,让服务器每隔一段时间自动执行一次 BGSAVE 操作.

用户可以通过 SAVA 选项设置多个保存条件,只要其中任意一个条件被满足,服务器就会执行BGSAVE 命令.

举个例子, 如果服务器有如下配置:

save 900 1
save 300 10
save 60 10000

那么只要满足下列三个条件中任意一个, BGSAVE 命令就会执行:

服务器在 900 秒之内,对数据库 进行了至少 1 次修改
服务器在 300 秒之内,对数据库 进行了至少 10 次修改
服务器在 60 秒之内,对数据库 进行了至少 10000次修改

二:aof持久化

rdb文件记录的是数据库的状态,相当于给所有的键值都做一次快照。但是aof文件记录的是更新操作的命令。
当 AOF 持久化功能处于打开状态时,服务器在执行完一个写命令后,会以协议格式将命令追加到服务器状态的 aof_buf 缓冲区末尾:

struct redisServer {
    //...
    sds aof_buf;   //AOF 缓冲区
    //...
};

由于端午节临近,需要去给丈母娘买稻香村,故待续。。。

参考

上一篇下一篇

猜你喜欢

热点阅读