在线客服
扫描二维码
下载博学谷APP扫描二维码
关注博学谷微信公众号
对于Java进阶的学习者来说,Redis备份方式是需要弄清楚的重点之一。Redis备份方式即RDB和AOF两种。本文就围绕着RDB和AOF进行阐述,主要分成redis持久化的两种方式、数据恢复和RDB和AOF对比总结三大部分,感兴趣的同学就继续看下去吧!
一、redis持久化的两种方式:
RDB: 对内存中数据库状态进行快照
AOF: 把每条写命令都写入文件
RDB方式:将redis在内存中的数据库状态保存到磁盘里面,RDB文件是一个经过压缩的二进制文件,通过该文件可以还原生成RDB文件的数据状态。
RDB的生成方式:
指向命令手动生成
通过配置自动生成
1.指向命令手动生成
有两个redis命令可以生成RDB文件,一个是SAVE,另一个是BGSAVE,SAVE命令会阻塞redis服务器进程,直到RDB文件创建完毕为止,在服务器阻塞期间,服务器不能处理任何的进程,BGSAVE会派出一个子进程,然后由子进程负责创建RDB。文件,服务器进程(父进程)继续处理命令请求,创建RDB文件结束之前,客户端发送的 BGSAVE 和 SAVE 命令会被服务器拒绝。
2.通过配置自动生成?
可以设置服务器配置的save选项,让服务器每隔一段时间自动执行一次BGSAVE命令,可以通过save选项设置多个保存条件,但只要其中任意一个条件被满足就会执行BGSAGE命令。
例如:
save 900 1
save 300 10
save 60 10000
那么只要满足以下三个条件中的其中一个,BGSAVE命令就会被执行
服务器在 900 秒之内,对数据库进行了 1 次修改
服务器在 300 秒之内,对数据库进行了 10 次修改
服务器在 60 秒之内,对数据库进行了 10000 次修改
AOF方式:是通过保存redis服务器所执行的写命令来记录数据库状态的AOF文件刷新方式,有三种:
1.appendfsync always -- 每提交一个修改命令都调用fsync到AOF文件,非常慢,但是很安全;
2.appendfsync everysec -- 每秒都调用fsyns刷新到AOF文件,很快但可能丢失一秒内的数据;
3.appendfsync no -- 依靠OS进行刷新,redis不主动刷新AOF,这样最快但是安全性差;
默认并且推荐每秒刷新,这样在速度和安全上都做到了兼顾
二、数据恢复
1.ROB方式
ROB文件的载入工作是在服务器启动时自动执行的,没有专门用于载入ROB文件命令,只要redis服务器再启动时检测到
ROB文件存在,它就会自动载入ROB的文件,在服务器载入的期间,会一直处于阻塞状态,直到载入工作完成为止
2.AOF方式
服务器在启动时,通过载入和执行AOF文件中保存的命令来还原服务器关闭之前的数据,具体过程:
载入AOF文件
创建模拟客户端
从AOF文件中读取一条命令
使用模拟客户端执行命令
循环读取并执行命令,直到全部完成
如果同时启动了AOF和ROB方式,AOF优先,启动时只加载AOF文件恢复数据
三、RDB和AOF对比总结
1、RDB
是在某个时间点将数据写入一个临时文件,持久化结束后,用这个临时文件替换上次持久化的文件,达到数据恢复。 这里说的这个执行数据写入到临时文件的时间点是可以通过配置来自己确定的,通过配置redis在n秒内如果超过m个key被修改这执行一次RDB操作。这个操作就类似于在这个时间点来保存一次Redis的所有数据,一次快照数据。所有这个持久化方法也通常叫做snapshots。
2、AOF
Append-only file,将“操作 + 数据”以格式化指令的方式追加到操作日志文件的尾部,在append操作返回后(已经写入到文件或者即将写入),才进行实际的数据变更,“日志文件”保存了历史所有的操作过程;当server需要数据恢复时,可以直接replay此日志文件,即可还原所有的操作过程。AOF相对可靠,它和mysql中bin.log、apache.log、zookeeper中txn-log简直异曲同工。AOF文件内容是字符串,非常容易阅读和解析。
3、两种备份方案的选择:
对于RDB持久化,
一方面是bgsave在进行fork操作时redis主进程会阻塞,
另一方面,子进程向硬盘写数据也会带来IO压力,但数据的完整性和一致性受备份条件影响可能较差;而AOF持久化由于持续的写入IO压力更大,但数据的一致性和完整性较好。
以上就是Redis备份方式RDB和AOF的总结。大家Java进阶学习的时候如果遇到许多问题,可以报博学谷的线上课程,不仅有优质的课程视频,还有专业老师为大家在线解答。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
Java线上培训班怎么选择?
Java线上培训班授课的优势不受时间、空间、教学环境的限制;教学资源较为优质,避免了要去外省或外市上课的时间成本。传统模式是线下授课,新兴起的是在线授课,其实两种授课方式各有所长,适应不同的人,两种学习方式相辅相成。
5641
2019-11-12 17:03:06
Java并发编程学习教程分享
并发编程作为Java程序员前进道路上的一座大山,学习起来是比较费劲的,因此许多程序员常常望而却步。但是无论是想进入的一线的互联网企业就职,还是想要提升自己的核心竞争力,Java并发编程都是必须掌握的重要技能。为了解决大家对于Java并发编程学习的困扰呢,下面小编将向大家介绍《Java并发编程原理精讲》课程,一起来看看具体的学习教程吧!
5692
2019-11-18 16:38:05
提高Java开发效率的十个编程好习惯
对于刚刚入门学习Java编程语言的初学者而言,学习Java的基础语法固然重要,养成良好的编程习惯也是在一开始就需要注意的学习重点。只有在一开始建立好基础的习惯,才能在后期的Java开发中,提高自己的编码水平和效率。在这里小编整理了提高Java开发效率的十个编程好习惯供大家参考,下面一起来看看吧!
5548
2020-03-02 14:29:25
JSP基础语法学习笔记总结
JSP作为一种动态网页开发技术,是以 Java 语言作为脚本语言,并且在服务端运行。因此,对于Java程序员来讲,掌握JSP基础语法是十分重要的。本文为大家总结了JSP基础语法学习笔记,内容包括了指令、注释和内置对象。下面让我们开始JSP基础语法的学习吧!
4528
2020-04-03 11:37:01
初级Java后端开发工程师需要学什么?
近几年,可以说是互联网飞速发展的几年。在IT技术人才日益紧缺的同时,程序员似乎遍地都是,好像只要会打几行代码,能做几个页面就是标准的开发工程师了。但其实一个技术开发工作者的要求远远没有那么低,下面我们来一起看看,初级Java后端开发工程师需要学什么?
9308
2020-07-17 15:40:26
热门文章
- 前端是什么
- 前端开发的工作职责
- 前端开发需要会什么?先掌握这三大核心关键技术
- 前端开发的工作方向有哪些?
- 简历加分-4步写出HR想要的简历
- 程序员如何突击面试?两大招带你拿下面试官
- 程序员面试技巧
- 架构师的厉害之处竟然是这……
- 架构师书籍推荐
- 懂了这些,才能成为架构师 查看更多
扫描二维码,了解更多信息
