热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

叨叨缓存中间件之Redis持久化机制

一、Redis持久化的必要性相信大家普遍都知道,Redis是NoSQL中的一员,其数据都保存在内存中。那我们知道,内存有一个特性就是断电

一、Redis持久化的必要性

相信大家普遍都知道,Redis是NoSQL中的一员,其数据都保存在内存中。那我们知道,内存有一个特性就是断电即失!所以,Redis的数据存储如果仅仅瞄准内存的话,数据的安全性和可靠性是无法得到保证的!故而,引申出Redis持久化机制。

那么,有关Redis持久化机制的详细解读又是怎样的呢?其实就是Redis的数据除了存储在内存中,还可以配置持久化策略:将Redis的数据保存到磁盘上。这样,即使Redis宕机或者服务故障,我们通过重启Redis服务,可以从磁盘中恢复历史数据。Redis持久化策略的应用,大大提升了数据的安全性和可靠性!


在这里插入图片描述



二、Redis如何实现持久化

Redis目前有2种方式进行数据的持久化:

  • RDB方式:在指定时间间隔内对数据进行快照存储
  • AOF方式:记录每次对Redis服务的数据写入操作命令,当服务重启时通过重新执行这些命令来恢复原始数据



2.1 RDB方式

2.1.1 客户端直接通过命令BGSAVE或者SAVE来创建一个内存快照

  • BGSAVE 调用fork来创建一个子进程,子进程负责将快照写入磁盘,父进程照常工作,不受任何影响。
  • SAVE 执行SAVE命令过程中,不再响应其他命令。


2.1.2 进入redis安装目录,找到redis.conf配置文件,在其内调整save命令的配置选项。redis发生数据写入操作的个数满足条件会触发BGSAVE命令的执行

# 900秒之内至少发生1次数据写入操作
save 900 1
# 300秒之内至少发生10次数据写入操作
save 300 10
# 60秒之内至少发生10000次数据写入操作
save 60 10000


2.1.3 RDB的优缺点

优点缺点
对性能影响最小同步时易丢失数据(具体看配置的数据写入时间间隔)
RDB快照文件在数据恢复速度上,比AOF要快得多如果数据集比较大且CPU不够强悍(比如单核CPU),Redis在fork子进程时可能要消耗相对较长的时间,会影响Redis对外提供服务的能力



2.2 AOF方式

2.2.1 开启AOF持久化

appendonly yes


2.2.2 AOF策略调整

# 每次有数据修改发生时都会写入AOF文件
appendfsync always# 每秒钟同步一次,该策略为AOF的缺省策略
appendfsync everysec# 从不同步。高效但是数据不会被持久化
appendfsync no


2.2.3 AOF的优缺点

优点缺点
最安全文件体积较大
容灾性能消耗比RDB要高
易读,可修改数据恢复速度上比RDB慢



推荐阅读
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文介绍了Redis中RDB文件和AOF文件的保存和还原机制。RDB文件用于保存和还原Redis服务器所有数据库中的键值对数据,SAVE命令和BGSAVE命令分别用于阻塞服务器和由子进程执行保存操作。同时执行SAVE命令和BGSAVE命令,以及同时执行两个BGSAVE命令都会产生竞争条件。服务器会保存所有用save选项设置的保存条件,当满足任意一个保存条件时,服务器会自动执行BGSAVE命令。此外,还介绍了RDB文件和AOF文件在操作方面的冲突以及同时执行大量磁盘写入操作的不良影响。 ... [详细]
  • Java工程师书单(初级,中级,高级)
    简介怎样学习才能从一名Java初级程序员成长为一名合格的架构师,或者说一名合格的架构师应该有怎样的技术知识体系,这是不仅一个刚刚踏入职场的初级程序员也是工作一两年之后开始迷茫的程序 ... [详细]
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • t-io 2.0.0发布-法网天眼第一版的回顾和更新说明
    本文回顾了t-io 1.x版本的工程结构和性能数据,并介绍了t-io在码云上的成绩和用户反馈。同时,还提到了@openSeLi同学发布的t-io 30W长连接并发压力测试报告。最后,详细介绍了t-io 2.0.0版本的更新内容,包括更简洁的使用方式和内置的httpsession功能。 ... [详细]
  • RouterOS 5.16软路由安装图解教程
    本文介绍了如何安装RouterOS 5.16软路由系统,包括系统要求、安装步骤和登录方式。同时提供了详细的图解教程,方便读者进行操作。 ... [详细]
  • 网卡工作原理及网络知识分享
    本文介绍了网卡的工作原理,包括CSMA/CD、ARP欺骗等网络知识。网卡是负责整台计算机的网络通信,没有它,计算机将成为信息孤岛。文章通过一个对话的形式,生动形象地讲述了网卡的工作原理,并介绍了集线器Hub时代的网络构成。对于想学习网络知识的读者来说,本文是一篇不错的参考资料。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 全面介绍Windows内存管理机制及C++内存分配实例(四):内存映射文件
    本文旨在全面介绍Windows内存管理机制及C++内存分配实例中的内存映射文件。通过对内存映射文件的使用场合和与虚拟内存的区别进行解析,帮助读者更好地理解操作系统的内存管理机制。同时,本文还提供了相关章节的链接,方便读者深入学习Windows内存管理及C++内存分配实例的其他内容。 ... [详细]
  • 本文介绍了关系型数据库和NoSQL数据库的概念和特点,列举了主流的关系型数据库和NoSQL数据库,同时描述了它们在新闻、电商抢购信息和微博热点信息等场景中的应用。此外,还提供了MySQL配置文件的相关内容。 ... [详细]
  • 本文介绍了H5游戏性能优化和调试技巧,包括从问题表象出发进行优化、排除外部问题导致的卡顿、帧率设定、减少drawcall的方法、UI优化和图集渲染等八个理念。对于游戏程序员来说,解决游戏性能问题是一个关键的任务,本文提供了一些有用的参考价值。摘要长度为183字。 ... [详细]
  • 旁路|发生_Day749.旁路缓存:Redis是如何工作的Redis 核心技术与实战
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Day749.旁路缓存:Redis是如何工作的-Redis核心技术与实战相关的知识,希望对你有一定的参考价值。 ... [详细]
  • MySQL笔记_MySQL笔记1|数据库17问17答
    本文由编程笔记#小编为大家整理,主要介绍了MySQL笔记1|数据库17问17答相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 14亿人的大项目,腾讯云数据库拿下!
    全国人 ... [详细]
  • 玩转直播系列之消息模块演进(3)
    一、背景即时消息(IM)系统是直播系统重要的组成部分,一个稳定的,有容错的,灵活的,支持高并发的消息模块是影响直播系统用户体验的重要因素。IM长连接服务在直播系统有发挥着举足轻重的 ... [详细]
author-avatar
天极玩家_136
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有