Redis持久化

2019-08-18  本文已影响0人  老陈的记事本

SAVE 同步保存到磁盘

可用版本: >= 1.0.0
时间复杂度: O(N), N 为要保存到数据库中的 key 的数量。

SAVE 命令执行一个同步保存操作,将当前 Redis 实例的所有数据快照(snapshot)以 RDB 文件的形式保存到硬盘。

一般来说,在生产环境很少执行 SAVE 操作,因为它会阻塞所有客户端,保存数据库的任务通常由 BGSAVE 命令异步地执行。然而,如果负责保存数据的后台子进程不幸出现问题时, SAVE 可以作为保存数据的最后手段来使用。

返回值

保存成功时返回 OK

代码示例

redis> SAVE
OK

例如,如果至少更改了1000个密钥,则此配置将使Redis每60秒自动将数据集转储到磁盘:

save 60 1000

BGSAVE 异步保存到磁盘

可用版本: >= 1.0.0
时间复杂度: O(N), N 为要保存到数据库中的 key 的数量。

在后台异步(Asynchronously)保存当前数据库的数据到磁盘。

BGSAVE 命令执行之后立即返回 OK ,然后 Redis fork 出一个新子进程,原来的 Redis 进程(父进程)继续处理客户端请求,而子进程则负责将数据保存到磁盘,然后退出。

客户端可以通过 LASTSAVE 命令查看相关信息,判断 BGSAVE 命令是否执行成功。

请移步 持久化文档 查看更多相关细节。

返回值

反馈信息。

代码示例

redis> BGSAVE
Background saving started

BGREWRITEAOF

可用版本: >= 1.0.0

时间复杂度: O(N), N 为要追加到 AOF 文件中的数据数量。

执行一个 AOF文件 重写操作。重写会创建一个当前 AOF 文件的体积优化版本。

即使 BGREWRITEAOF 执行失败,也不会有任何数据丢失,因为旧的 AOF 文件在 BGREWRITEAOF 成功之前不会被修改。

重写操作只会在没有其他持久化工作在后台执行时被触发,也就是说:

从 Redis 2.4 开始, AOF 重写由 Redis 自行触发, BGREWRITEAOF 仅仅用于手动触发重写操作。

请移步 持久化文档(英文) 查看更多相关细节。

返回值

反馈信息。

代码示例

redis> BGREWRITEAOF
Background append only file rewriting started

LASTSAVE

可用版本: >= 1.0.0
时间复杂度: O(1)

返回最近一次 Redis 成功将数据保存到磁盘上的时间,以 UNIX 时间戳格式表示。

返回值

一个 UNIX 时间戳。

代码示例

redis> LASTSAVE
(integer) 1324043588

上一篇 下一篇

猜你喜欢

热点阅读