Redis 持久化扫盲了

伽叶
• 阅读 1102

唠个嗑

现在的面试要求是越来越难了,想当初毕业后面试开发岗位如果你会使用 Redis ,在面试官心中就会觉得,哎呦,你挺不错哦,算是加分项。现在的 Redis 成为了开发者的必备技能,面试如果没用过或不会用 Redis,那你就真的可能被劝退了。不停的学习新技术,或许就是开发者的宿命。

持久化

Redis 可以用来做缓存,也属于 NoSQL 数据库,所以也支持数据持久化,Redis 数据库支持两种持久化方案:

  1. RDB 快照
  2. AOF 日志
  3. 混合持久化

RDB

配置参数

redis.conf 涉及的主要配置

#1、自动备份规则(满足一个条件就会触发备份动作)
save 900 1 #每隔900秒有1次修改则触发
save 300 10 #每隔300秒有10次修改则触发
save 60 10000 #每隔60秒有10000次修改则触发

#2、是否快照备份出现错误后禁止客户端写入,默认是 yes
stop-writes-on-bgsave-error yes

#3、是否对快照文件进行压缩,默认 yes
rdbcompression yes

#4、是否对 RDB 文件进行校验,默认 yes
rdbchecksum yes

#5、定义生成的 RDB 文件名,默认 dump.rdb
dbfilename dump.rdb

#6、定义生成 RDB 文件目录,默认是启动 Redis 服务的目录
dir ./
刚安装好的 Redis,默认开启的是这种持久化方式,在启动服务的目录会备份一个 dump.rdb 文件,Redis 启动的时候会自动加载这个文件来恢复备份的数据。

备份

  1. 我们可以通过 Redis 客户端发送命令 save 手动备份当前数据的快照,但是 save 是阻塞命令,当备份文件过大,备份操作没有完成时,期间接收的其他操作命令将会被挂起。所以不建议使用 save,这时候出现了 bgsave,见名知意,它会 fork 一个子进程来处理备份操作,不影响主进程处理客户端请求命令。
  2. 触发配置的自动备份策略,会自动执行 bgsave。
  3. 执行 shutdown 命令,会触发 save 命令,备份完成后才会服务关闭。
  4. 搭建主从复制时,在从机连上主机之后,会自动发送一条 sync 同步命令,主机收到命令

之后,首先执行 bgsave 对数据进行快照备份,然后才会给从机发送快照数据进行同步。

AOF

配置参数

#1、开启 aof 配置,默认 no
appendonly yes

#2、定义生成的 AOF 文件名
appendfilename "appendonly.aof"

# 3、自动备份规则(选择一个即可)
# appendfsync always #每次修改都备份
appendfsync everysec #每秒钟备份一次
# appendfsync no #由操作系统自动调度刷磁盘

#4、是否 aof 文件压缩时还继续进行同步操作,默认 no
no-appendfsync-on-rewrite no

#4、定义当目前 aof 文件大小超过上一次重写时的 aof 文件大小的百分之多少的时候,再次进行重写
auto-aof-rewrite-percentage 100

#5、如果之前没有重写过,则以启动时的 aof 大小为依据,同时要求 aof 文件至少要大于 64M
auto-aof-rewrite-min-size 64mb
默认 AOF 是没有开启的,AOF 持久化是将被执行的命令追加到 AOF 文件尾部,数据恢复时把命令从头到尾执行一遍
使用 AOF 方式做持久化,可以把 RDB 持久化的策略注释掉
save ""
#save 900 1
#save 300 10
#save 60 10000

混合持久化

此功能是 Redis4 之后新增的,说实话我也是前几天刚了解到的,接触的不多,这里也简单做个介绍吧,想深入的那只能让您失望了,出门左拐直走......

配置参数

aof-use-rdb-preamble yes

备份方式

通过上面参数设为 yes 来开启,在数据写入的时候先把数据以 RDB 的格式放在文件开头,再将后续的命令以 AOF 的格式追加到文件后面,这样算是引进了 RDB 数据恢复速度快的优点 和 AOF 数据丢失风险小的优点。

Redis 部分思维脑图

Redis 持久化扫盲了
如果感觉图片不清楚,公号 charmsongo 回复 Redis 获取

如果有哪些不对的地方烦请指认,先行感谢
点赞
收藏
评论区
推荐文章
美凌格栋栋酱 美凌格栋栋酱
7个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
菜鸟阿都 菜鸟阿都
4年前
springBoot集成redis
Redis作为一个Java后端面试中的一个常问考点,并且在项目中越来越常用,所以自己动手搭建了一个基于springboot集成redis做为数据缓存的demo(springboot集成mybatis、redis,并具有增删改查询接口)。关注微信公众号【菜鸟阿都】并回复:redis,可获得源码。后面也会继续深入研究redis相关知识,期待与大家一起学习交流。r
Karen110 Karen110
4年前
​一篇文章总结一下Python库中关于时间的常见操作
前言本次来总结一下关于Python时间的相关操作,有一个有趣的问题。如果你的业务用不到时间相关的操作,你的业务基本上会一直用不到。但是如果你的业务一旦用到了时间操作,你就会发现,淦,到处都是时间操作。。。所以思来想去,还是总结一下吧,本次会采用类型注解方式。time包importtime时间戳从1970年1月1日00:00:00标准时区诞生到现在
Stella981 Stella981
3年前
Redis面试连环问,快看看你能走到哪一步
今天,我不自量力的面试了某大厂的java开发岗位,迎面走来一位风尘仆仆的中年男子,手里拿着屏幕还亮着的mac,他冲着我礼貌的笑了笑,然后说了句“不好意思,让你久等了”,然后示意我坐下,说:“我们开始吧。看了你的简历,觉得你对redis应该掌握的不错,我们今天就来讨论下redis……”。我想:“来就来,兵来将挡水来土掩”。Redis是什么
可莉 可莉
3年前
051. Redis 持久化机制
1\.持久化介绍Redis的数据存在在内存中,如果没有配置持久化,redis重启后数据就全丢失了,于是需要开启redis的持久化功能,将数据保存到磁盘上,当redis重启后,可以从磁盘中恢复数据。!image20200511165351687(https://oscimg.oschina.net/os
Stella981 Stella981
3年前
Redis都不懂?就别去面试了!聊聊我的Redis新专栏「视频版」
前不久,有一个读者在后台留言,说他面试Java开发工程师岗位时,居然大部分的面试问题都是关于Redis,他都差点都忘记了自己应聘的是Java工程师了。而然这种现象在现在的后端面试中很常见,对Redis的掌握已经变成了一项后端工程师必须具备的基础技能了。刚好借此机会和大家聊聊,如何学习Redis?当然还有我的新专栏《Redis核心原理与
Stella981 Stella981
3年前
Redis 存储原理(1)
Redis现在基本也算是后台开发的基础服务,基本像Mysql一样普遍在应用中使用了。我第一次接触的Nosql是memcache用来解决夸服务session共享问题。后来因为memcache无法持久化问题改为使用Redis。这次主要针对Redis做一个整理。Redis数据类型类型特点说明String类型是Redis最基本的数据类
Stella981 Stella981
3年前
Nginx + lua +[memcached,redis]
精品案例1、Nginxluamemcached,redis实现网站灰度发布2、分库分表/基于Leaf组件实现的全球唯一ID(非UUID)3、Redis独立数据监控,实现订单超时操作/MQ死信操作SelectPollEpollReactor模型4、分布式任务调试Quartz应用
Stella981 Stella981
3年前
Redis存储方式RDB和AOF介绍及持久化的重要性
更多精彩和干货和你分享前言redis可以干很多事情,我们这里的背景是将redis作为缓存服务器还讨论的。如果部署了一个redis,主从也好,cluster也罢,我将一些数据存储在它上面,如果没有持久化的话,redis只会存储到内存中,那如果遇到灾难性故障,就会丢失所有数据。这对企业级的应用来说,是个噩梦。如果我们能将数据持久化
Stella981 Stella981
3年前
051. Redis 持久化机制
1\.持久化介绍Redis的数据存在在内存中,如果没有配置持久化,redis重启后数据就全丢失了,于是需要开启redis的持久化功能,将数据保存到磁盘上,当redis重启后,可以从磁盘中恢复数据。!image20200511165351687(https://oscimg.oschina.net/os
子非鱼 子非鱼
3年前
Redis高级
第一章Redis的持久化由于redis是一个内存数据库,所有的数据都是保存在内存当中的,内存当中的数据极易丢失,所以redis的数据持久化就显得尤为重要,在redis当中,提供了两种数据持久化的方式,分别为RDB以及AOF,且Redis默认开启的数据持久化方式为RDB方式。1、RDB持久化方案Redis会定期保存数据快照至一个rbd文件中,并在启动时自动