Redis——持久化之RDB

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis——持久化之RDB

1.RDB(Redis DataBase)


在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是行话讲的Snapshot快照,它恢复时是将快照文件直接读到内存里。


1.1 RDB备份是如何执行的?


Redis会单独创建(fork)一个子进程来进行持久化,会将数据入到一个临时文件中,待持久化过程都结束了,再用这个临时文件替换上次持久化好的文件。整个过程中,主进程是不进行任何IO操作的,这就确保了极高的性能如果需要进行大规模数据的恢复,且对于数据恢复的完整性不是非常敏感,那RDB方式要比AOF方式更加的高效。RDB的缺点是最后一次持久化后的数据可能丢失


1.2 关于fork

1.    Fork的作用是复制一个与当前进程一样的进程。新进程的所有数据(变量、环境变量、程序计数器等)数值都和原进程一致,但是是一个全新的进程,并作为原进程的子进程

2.    Linux程序中,fork()会产生一个和父进程完全相同的子进程,但子进程在此后多会exec系统调用,出于效率考虑,Linux中引入了写时复制技术

3.    一般情况父进程和子进程会共用同一段物理内存,只有进程空间的各段的内容要发生变化时,才会将父进程的内容复制一份给子进程。


1.3 RDB持久化流程


1.4 RDB持久化文件:dump.rdb

redis.conf中配置文件名称,默认为dump.rdb


rdb文件的保存路径,也可以修改。默认为Redis启动时命令行所在的目录下。


如何触发RDB快照;保持策略。

配置文件中默认的快照配置,这三行save代码的意思是:

3600秒(一个小时)内,如果有1个数据发生改变,则进行持久化。

30秒内,如果有10个数据发生改变,则进行持久化。(原先是 save 300 100),我为了后面测试RDB,这里进行了修改。

60秒内,如果有10000个数据发生改变,则进行持久化。


savesave时只管保存,其它不管,全部阻塞。手动保存。不建议。

bgsaveRedis会在后台异步进行快照操作,快照同时还可以响应客户端请求。

可以通过lastsave 命令获取最后一次成功执行快照的时间


stop-writes-on-bgsave-error:当Redis无法写入磁盘的话,直接关掉Redis的写操作。推荐yes.


rdbcompression压缩文件:对于存储到磁盘中的快照,可以设置是否进行压缩存储。如果是的话,redis会采用LZF算法进行压缩。

如果你不想消耗CPU来进行压缩的话,可以设置为关闭此功能。推荐yes.


rdbchecksum检查完整性:在存储快照后,还可以让redis使用CRC64算法来进行数据校验,

但是这样做会增加大约10%的性能消耗,如果希望获取到最大的性能提升,可以关闭此功能。推荐yes.


1.5 RDB的优势/劣势


优势:

1.    适合大规模的数据恢复

2.    对数据完整性和一致性要求不高更适合使用

3.    节省磁盘空间

4.    恢复速度快


劣势:

1.    Fork的时候,内存中的数据被克隆了一份,大致2倍的膨胀性需要考虑

2.    虽然Redisfork时使用了写时拷贝技术,但是如果数据庞大时还是比较消耗性能。

3.    在备份周期在一定间隔时间做一次备份,所以如果Redis意外down掉的话,就会丢失最后一次快照后的所有修改。


1.6 演示RDB

首先redis中还没有存储任何键值对数据。


我在上面的截图中,修改了持久化RDB的策略:save 30 1030秒内,如果有10个数据发生了改变,则进行持久化)

下面我先向redis中添加12个数据,确保30秒有多于10个数据发生了改变。


 


数据添加完毕,我们再次查看dump.rdb文件,它的大小增加了,这是自然的。


下面,我们将这个文件拷贝一份。


之后,关闭redis。同时删除RDB原先的持久化文件dump.rdb。然后将这个dump2.rdb改名为:dump.rdb


然后,我们重启redis服务,再次查看这其中都有哪些key(之前我们set12key,这12key是否全部被持久化呢?)


在这里可以看到,redisRDB只持久化了10个数据,这也对应了 save 30 10 这条指令。

30秒内,如果有10个数据发生了改变,那么将进行持久化操作。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
3月前
|
监控 NoSQL Linux
【分布式】Redis的持久化方案解析
【1月更文挑战第25天】【分布式】Redis的持久化方案解析
|
11天前
|
存储 NoSQL 算法
redis数据持久化
redis数据持久化
|
21天前
|
缓存 NoSQL Shell
【Redis深度专题】「核心技术提升」探究Redis服务启动的过程机制的技术原理和流程分析的指南(持久化功能分析)
【Redis深度专题】「核心技术提升」探究Redis服务启动的过程机制的技术原理和流程分析的指南(持久化功能分析)
25 0
|
1月前
|
缓存 NoSQL Redis
[Redis]——Redis持久化的两种方式RDB、AOF
[Redis]——Redis持久化的两种方式RDB、AOF
|
1月前
|
NoSQL 关系型数据库 MySQL
Redis 两种持久化方式 AOF 和 RDB
Redis 两种持久化方式 AOF 和 RDB
|
1月前
|
NoSQL Redis 数据库
【怒怼大厂面试官】听说你精通Redis?说说Redis持久化
咳咳咳,看你简历写了精通Redis,那我就随便问问。主要有RDB持久化、AOF持久化。是这样,Redis服务器会维护一个AOF重写缓冲区,该缓冲区会在子进程创建新AOF文件期间,记录服务器执行的所有写命令。
51 1
【怒怼大厂面试官】听说你精通Redis?说说Redis持久化
|
2月前
|
存储 NoSQL Redis
Redis淘汰策略、持久化、主从同步与对象模型
Redis淘汰策略、持久化、主从同步与对象模型
88 0
|
2月前
|
NoSQL Redis 数据库
Redis的安全网:掌握RDB和AOF的持久化技术【redis第四部分】
Redis的安全网:掌握RDB和AOF的持久化技术【redis第四部分】
119 0
|
2月前
|
NoSQL Redis
spring-state-machine使用redis持久化
spring-state-machine使用redis持久化
27 0
|
5月前
|
存储 移动开发 NoSQL
微服务轮子项目(29) -Redis 单机、主从复制、哨兵、cluster集群、持久化方案(下)
微服务轮子项目(29) -Redis 单机、主从复制、哨兵、cluster集群、持久化方案(下)
51 0

热门文章

最新文章