前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Redis实战(二)Redis 的 RDB 配置和数据恢复

Redis实战(二)Redis 的 RDB 配置和数据恢复

作者头像
用户10168815
发布2023-02-28 12:29:19
1.1K0
发布2023-02-28 12:29:19
举报
文章被收录于专栏:架构进阶之路

RDB 配置解释

在 redis.conf 文件中,默认有 RDB 持久化配置:

代码语言:javascript
复制
save 900 1
save 300 10
save 60 10000

解释:

  • 这些配置称为检查点。
  • 每隔 900s,如果有至少 1 个 key发生了变更,就生成一个新的 dump.rdb 文件,这个 dump.rdb 文件就是 redis 内存中完整的数据快照,也叫做 snapshotting。
  • 同上,每隔 300s,检查是否有 10 个key 发生了变更,或者每隔 60s,检查是否有 10000个 key 发生了变更,如果有,则生成 dump.rdb 文件。
  • 可以配置多项检查点。
  • 可以移除所有检查点,只需要这样配置即可:save "",或者移除所有配置项。

RDB 持久化的工作流程

(1)Redis 根据配置尝试生成 rdb 快照文件。

(2)Redis fork 一个子进程。

(3)子进程尝试将数据 dump 到一个临时的 RDB 快照文件中。

(4)完成快照后,就把临时文件替换掉之前生成的 RDB 文件。

RDB 实验

实验(1)测试 Redis 被 shutdown 时,Redis 是否会丢失数据。

首先重启 Redis,让检查点的时间窗口重置。

代码语言:javascript
复制
redis-cli shutdown
cd /etc/init.d
./redis_6379 start
ps -ef | grep redis

然后往 Redis 中插入几条数据:

代码语言:javascript
复制
redis-cli
set key1 abc
set key2 222
get key1
get key2

目前只设置了 2 个 key,且还没有到 900 s,所以不会触发自动生成 RDB 快照。

这个时候我们可以猜测下重启 redis 后,刚刚插入的两个 key 是否被持久化到 dump 文件中了。

我们来测试下:

重启 Redis,获取 key1 和 key2:

代码语言:javascript
复制
redis-cli shutdown
cd /etc/init.d
./redis_6379 start
ps -ef | grep redis
redis-cli
get key1
get key2

会看到 Redis 重启后还是存在 key1 和 key2,并不会丢失。

另外还可以找下 dump.rdb 文件,更新时间更新为 shutdown 的时间。

结论:shutdown 时,Redis 不会丢失丢失,会将内存中的数据立即生成一份完整 RDB 快照。

实验(2)用 kill -9 直接干掉 Redis,模拟 Redis 故障,验证数据是否会丢失。

首先插入几条新数据

代码语言:javascript
复制
redis-cli
set key3 333
set key4 444
get key3
get key4

然后获取 Redis 的进程 id

代码语言:javascript
复制
ps -ef | grep redis

Redis PID=1485,然后用 kill -9 干掉 Redis 进程:

代码语言:javascript
复制
kill -9 1485

然后重启 Redis

代码语言:javascript
复制
cd /var/run
rm -rf redis_6379.pid
cd /etc/init.d
./redis_6379 start

然后获取 key3 和 key4,发现没有这两个 key。

代码语言:javascript
复制
get key3
get key4

我们也可以查看下 dump.rdb 文件的更新时间是否有改变:

如果我们想要保证减少 Redis 故障导致的数据丢失,可以通过设置一个频率更高的检查点,每 5s 检查一次,如果有至少一条数据更新,则进行 RDB 快照。如下所示的配置:

代码语言:javascript
复制
save 5 1

但是如果故障正好发生在快照之前,那么变更的数据就没有生成到 RDB 文件中了。

而且生成的 RDB 的频率过高,而且变更的数据量很大的话,生成 RDB 的文件也会很大,操作 IO 的时间也会变长,长时间占用磁盘 IO 会造成性能问题。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-02-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • RDB 配置解释
  • RDB 持久化的工作流程
  • RDB 实验
    • 实验(1)测试 Redis 被 shutdown 时,Redis 是否会丢失数据。
      • 实验(2)用 kill -9 直接干掉 Redis,模拟 Redis 故障,验证数据是否会丢失。
      相关产品与服务
      云数据库 Redis®
      腾讯云数据库 Redis®(TencentDB for Redis®)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档