文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Redis持久化方案RDB和AOF(理论)

2024-04-02 19:55

关注

redis和memcache的区别是什么?

    简单来说,如果没有持久化的redis,就和memcache一样了,相当于一个缓存数据库。


redis是如何解决数据持久化的?

    redis有两种持久化方案:RDB(Redis DataBases)和AOF(AppendOnly File)


RDB持久化(详细分析:https://blog.51cto.com/13690439/2118462)

    RDB是snapshot快照<二进制文件>存储,是默认的持久化方式。

    RDB会按照一定的策略,周期性的将数据保存到磁盘。(下个周期为到来时故障,会丢数据)

    借助fork命令的copy on write机制,在快照生成时,将当前进程fork出一个子进程,

    然后再子进程中循环所有数据,将数据写成RDB文件。


AOF持久化(详细分析:https://blog.51cto.com/13690439/2118465)

    AOF<二进制文件>比RDB方式有更好的持久性。

    redis会将每一个收到的写命令都通过write函数追加到文件最后,类似msyql的binlog。

    当redis重启时,会通过重新执行文件中保存的写命令来在内存中重建整个数据库的内容。


简单来说:

    RDB:是按照策略周期性的进行持久化数据;

    AOF:是不断的去记录修改操作;


持久化方式的选择:

    RDB和AOF操作都是顺序IO操作,性能都很高。

    而同时在通过RDB文件或者AOF日志进行数据库恢复的时候,也是顺序的读取数据加载到内存中。

    所以也不会造成磁盘的随机读。


    通常,如果你要想提供很高的数据保障性,那么建议你同时使用两种持久化方式。

    如果你可以接受灾难带来的几分钟的数据丢失,那么你可以仅使用RDB。


在数据恢复方面:

    RDB的启动时间会更短,原因有两个:

        1、RDB文件中每一条数据只有一条记录,不会像AOF日志那样可能有一条数据的多次操作记录。

             所以每条数据只需要写一次就行了。

        2、RDB文件的存储格式和Redis数据在内存中的编码格式是一致的,不需要再进行数据编码工作,

             所以在CPU消耗上要远小于AOF日志的加载。 

市场常见架构:

      目前,通常的设计思路是利用Replication机制来弥补aof、snapshot性能上的不足,达到了数据可持久化。

      即Master上Snapshot和AOF都不做,来保证Master的读写性能,

      而Slave上则同时开启Snapshot和AOF来进行持久化,保证数据的安全性。


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯