在线客服
扫描二维码
下载博学谷APP
扫描二维码
关注博学谷微信公众号
Redis持久化机制实现原理是什么?流程是什么?持久化就是把内存中的数据存放到磁盘中,防止宕机后内存数据丢失。按照指定的时间间隔内将内存的数据以快照的形式保存到硬盘中,对应产生的数据文件为dump.rdb。通过配置文件中的save参数来定义快照的周期。
Redis的持久化机制,以及在实际业务中,我们应该如何选择比较合理的方式,能够更好的解决我们的问题
Redis持久化机制实现原理是什么?
持久化:Redis是内存数据库,数据都是存储在内存中,为了避免进程退出导致数据的永久丢失,需要定期将Redis中的数据以某种形式(数据或命令)从内存保存到硬盘;当下次Redis重启时,利用持久化文件实现数据恢复。除此之外,为了进行灾难备份,可以将持久化文件拷贝到一个远程位置
持久化流程是什么?
既然redis的数据可以保存在磁盘上,那么这个流程是什么样的呢?
要有下面五个过程:
(1)客户端向服务端发送写操作(数据在客户端的内存中)。
(2)数据库服务端接收到写请求的数据(数据在服务端的内存中)。
(3)服务端调用write这个系统调用,将数据往磁盘上写(数据在系统内存的缓冲区中)。
(4)操作系统将缓冲区中的数据转移到磁盘控制器上(数据在磁盘缓存中)。
(5)磁盘控制器将数据写到磁盘的物理介质中(数据真正落到磁盘上)。
这5个过程是在理想条件下一个正常的保存流程,但是在大多数情况下,我们的机器等等都会有各种各样的故障,这里划分了两种情况:
Redis数据库发生故障,只要在上面的第三步执行完毕,那么就可以持久化保存,剩下的两步由操作系统替我们完成;操作系统发生故障,必须上面5步都完成才可以。
为应对以上5步操作,redis提供了两种不同的持久化方式:RDB(Redis DataBase)和AOF(Append Only File)
RDB的快照、AOF的重写都需要fork,这是一个重量级操作,会对Redis造成阻塞。因此为了不影响Redis主进程响应,我们需要尽可能降低阻塞。
1.降低fork的频率,比如可以手动来触发RDB生成快照、与AOF重写;
2.控制Redis最大使用内存,防止fork耗时过长;
3.使用更牛逼的硬件;
4.合理配置Linux的内存分配策略,避免因为物理内存不足导致fork失败
线上实践经验:
1.如果Redis中的数据并不是特别敏感或者可以通过其它方式重写生成数据,可以关闭持久化,如果丢失数据可以通过其它途径补回;
2.自己制定策略定期检查Redis的情况,然后可以手动触发备份、重写数据;
3.可以加入主从机器,利用一台从机器进行备份处理,其它机器正常响应客户端的命令;
4.RDB持久化与AOF持久化可以同时存在,配合使用。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
Java在线培训课程内容是什么?需要学习那些知识点?
Java在线培训课程内容是什么?需要学习那些知识点?Java课程内容主要包括Java基础、Javaweb、主流框架、流行框架、以及各种实战项目等等。逐步深入学习,最终贴合目前企业用人需求,掌握各种实用的框架以及项目开发技术。
8978
2019-08-08 11:56:31
Java免费视频教程学习来博学谷
Java免费视频教程学习,小编整理了博学谷在线IT培训平台关于Java开发的免费课程,大家可以在线视频学习Java基础的专业知识及Java发展趋势及职业规划等内容,Java免费视频教程主要介绍:Java秒杀系统实战、2小时看清Java未来规划、Java基础语法、JavaEE与人工智能、Springmvc+Mybatis课程。
8238
2019-08-01 16:08:02
Apollo如何快速入门?
如今,Apollo已经开始在很多的技术公司流行起来了,因此对于技术有要求的提IT工作者不妨现在就学起来。那么Apollo如何快速入门?比起自己一点点啃枯燥的文字理论,这里给大家推荐一个更有效的学习方式,即观看优质的免费视频课程进行学习,这样可以帮助大家快速掌握Apollo的特性、安装、工作原理和项目场景等等内容。
5377
2020-03-18 18:39:32
想要参加IT培训学Java好不好?
想要参加IT培训,学java好不好?现如今可以说Java在所有编程语言里现阶段里前景是最好的应用也是非常广泛的Java应用广泛的很多,在金融,银行,PC,移动设备,就连传统企业也有在应用Java方面的人才,并且薪资也是非常高的,只要你学会了就不要发愁工作的问题。
4373
2020-04-01 17:46:08
Java工程师避免内卷,看这篇就够了!
大家可能也都感觉到Java程序员也越来越来卷了,特别是初中级Java工程师更卷了;大家都有着类似的工作经历,你会的技术我也会。所以,如何破解这种职业瓶颈? 那就看谁更能卷了,谁能更快的学习,快速进入到高级、甚至架构师的行列,谁就能拥有话语权,在Java这个方向立稳脚跟。
3068
2022-09-16 10:44:41
