Redis持久化 - RDB模式

Redis作为一种内存型数据库,它将所有的数据都保存在服务器内存中。所以如果不想办法将存储在内存中的数据保存到磁盘里面,那么一旦服务器故障或者断电导致服务器进程推出,那么Redis中保存的数据都将消失不见。

为此,Redis 提供了数据持久化机制,它能够在 Redis 运行过程中将内存中的数据持久化到磁盘中,万一服务器故障导致进程意外退出,可以根据持久化出来的文件恢复 Redis 数据。目前 Redis 提供的持久化模式有两种:RDB模式和AOF模式。

RDB 持久化功能所生成的 RDB 文件是一个经过压缩的二进制文件,通过该文件我们可以还原生成该 RDB 文件时数据库的状态。因为 RDB 文件是保存在磁盘中的,所以即便 Redis 服务进程退出,甚至运行 Redis 服务器的计算机宕机,只要磁盘中 RDB 文件存在,我们就能将数据恢复。

一、RDB 文件的创建与载入

有两个命令能生成 RDB 文件,一个是 SAVE,另一个是 BGSAVE。

这两者实现的功能相同,唯一的区别就是 SAVE 命令会阻塞 Redis 服务器进程,直到 RDB 文件生成完毕,在此期间将无法执行新的命令。BGSAVE 命令不会阻塞服务器进程,它采用的方法是派生一个子进程,然后由子进程去生成 RDB 文件,服务器进程则可以继续执行新的命令。

图一、redis.conf 文件<

如图一所示,配置文件 redis.conf 文件中说明了生成的 RDB 文件的名称以及保存路径,当然这些都是可以自定义的。保存路径采用了相对路径的方式,默认跟 redis.conf 文件保存在一个文件夹下(/etc/redis-5.0.7/etc/dump.rdb)。

生成 RDB 文件后,该文件的载入过程是在 Redis 服务器启动过程中载入的,只要 Redis 服务器在启动过程中检测到 RDB 文件的存在,他就会自动载入 RDB 文件。相较于 AOF 持久化模式生成的 AOF 文件,RDB 文件的更新频率更慢,所以:

  • 如果服务器开启了 AOF 持久化功能,那么服务器会优先使用 AOF 文件来还原数据。
  • 只有 AOF 持久化功能处于关闭状态,服务器才会使用 RDB 文件来还原数据

二、自动间隔性保存

除了上面提到的 SAVE 和 BGSAVE 命令可以手动生成 RDB 文件外。用户也可以在配置文件中的 save 选项设置多个保存条件,只有任何一个条件满足,服务器都会执行 BGSAVE 命令。redis 服务器设置自动间隔保存为:

图二、默认自动保存时间间隔

对上述配置的解释是:

  • 服务器在900秒之内,对数据库进行了至少1次修改
  • 服务器在300秒之内,对数据库进行了至少10次修改
  • 服务器在60秒之内,对数据库进行了至少100000次修改
图三、redis 日志文件

图三是我在执行一次 set msg hello 命令后,触发了 redis 自动保存条件而进行的一个 BDGSAVE 操作。

对于生成的 RDB 文件我们可以使用 od 命令去查看文件:

图四、生成的RDB文件

三、 RDB 持久化的优缺点

1、优势

  • RDB 文件保存了 Redis 在某一时刻的数据信息,恢复的时候直接加载到内存即可,不用做其他处理,这种文件适合用于做灾备处理
  • RDB 在恢复大数据集的时候比 AOF 恢复速度快

2、劣势

  • RDB 难以做到实时的数据持久化,发生事故时,上一次持久化时间到事故发生时的数据将无法得到持久化,恢复时造成数据丢失。
  • RDB 做持久化时都是新建一个子进程去处理,如果Redis 数据量比较大,那么子进程去生成 RDB 文件的时间将会比较长

知乎个人主页链接

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,470评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,393评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,577评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,176评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,189评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,155评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,041评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,903评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,319评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,539评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,703评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,417评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,013评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,664评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,818评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,711评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,601评论 2 353