基于内存的分布式NoSQL数据库Redis(六)AOF设计

news/2024/7/24 1:04:56 标签: 分布式, nosql, redis

文章目录

    • 知识点21:Redis持久化:AOF设计
    • 知识点22:Redis持久化:AOF实现
    • 附录一:Jedis Maven依赖

知识点21:Redis持久化:AOF设计

  • 目标:掌握Redis的AOF持久化机制

  • 路径

    • step1:问题
    • step2:AOF方案
    • step3:优缺点
    • step4:持久化方案
  • 实施

    • 问题

      RDB存在一定概率的数据丢失,如何解决?
      
    • AOF方案

      • 思想

        • 按照一定的规则,将内存数据的操作日志追加写入一个文件中
        • 当Redis发生故障,重启,从文件中进行读取所有的操作日志,恢复内存中的数据
        • 重新对Redis进行执行,用于恢复内存中的数据
      • 过程

        image-20210521164135479

      • 实现:追加的规则

        • appendfsync always
          • 每更新一条数据就同步将这个更新操作追加到文件中
          • 优点:数据会相对安全,几乎不会出现数据丢失的情况
          • 缺点:频繁的进行数据的追加,增大磁盘的IO,导致性能较差
        • appendfsync everysec
          • 每秒将一秒内Redis内存中数据的操作异步追加写入文件
          • 优点:在安全性和性能之间做了权衡,性能要比always高
          • 缺点:有数据丢失风险 ,但最多丢失1秒
        • appendfsync no
          • 交给操作系统来做,不由Redis控制
          • 肯定不用的
    • 优缺点

      • 优点:安全性和性能做了折中方案,提供了灵活的机制,如果性能要求不高,安全性可以达到最高

      • 缺点

        • 这个文件是普通文本文件,相比于二进制文件来说,每次追加和加载比较慢

        • 数据的变化以追加的方式写入AOF文件

          • 问题:文件会不断变大,文件中会包含不必要的操作【过期的数据】
          • 解决:模拟类似于RDB做全量的方式,定期生成一次全量的AOF文件
    • 应用:数据持久化安全方案,理论上绝对性保证数据的安全

    • 持久化方案:两种方案怎么选?

      • 两种方案都可以用:默认不配置AOF,使用的RDB
      • 问题**:两种都用,**重启Redis加载的是谁的数据?
        • 加载AOF
  • 小结

    • 什么是AOF机制?

      • 按照一定的规则将内存中的变化追加记录在一个日志文件中
      • 规则
      • always:内存变化一条,就追加磁盘一条,安全性高,性能差
        • everysesc:每一秒将这一秒内存的变化追加到磁盘中,安全和性能做了折中
        • no:不用
      • 优点
      • 安全和性能的选择更加灵活,安全性更高
      • 缺点
      • 追加到普通日志文件:相比于二进制来追加和恢复都要慢一些
        • 日志文件越来越大,里面会包含很多无用数据操作:根据规则来构建全量的AOF
      • 应用:Redis作为数据库或者缓存

知识点22:Redis持久化:AOF实现

  • 目标:实现AOF持久化

  • 实施

    • 开启并配置

      vim redis.conf
      #594行:开启aof
      appendonly yes
      #624行:默认每s刷写一次
      appendfsync everysec
      #665,666
      #增幅100%就重新覆盖一次
      auto-aof-rewrite-percentage 100
      #文件至少要大于64MB,一般建议更改为GB大小
      auto-aof-rewrite-min-size 64mb
      
    • 重启Redis

      shutdown
      redis-start.sh
      
  • 查看数据

      keys *
    

    image-20210522103318073

    • 从AOF文件恢复数据
  • 查看aof文件

      ll /export/server/redis/datas
    

    image-20210522103432092

  • 小结

    • 实现AOF持久化

附录一:Jedis Maven依赖

    <properties>
        <jedis.version>3.2.0</jedis.version>
    </properties>

    <dependencies>
        <!-- Jedis 依赖 -->
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>${jedis.version}</version>
        </dependency>
        <!-- JUnit 4 依赖 -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.0</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                    <encoding>UTF-8</encoding>
                </configuration>
            </plugin>
        </plugins>
    </build>

http://www.niftyadmin.cn/n/5099767.html

相关文章

JavaScript querySelector

querySelector方法的语法&#xff1a; var element document.getElementById("id"); element.querySelector(selector)element是要执行选择操作的父元素&#xff0c;selector是CSS选择器&#xff0c;用于指定要选择的元素。 querySelector方法返回匹配选择器的第一…

【vue3】注册全局组件

//main.tsimport CardVue from ./components/Card.vueconst app createApp(App) app.component(Card,CardVue)

【Release】Photoshop ICO file format plug-in 3.0

【Introduction】 The Photoshop ICO plug-in is a file format plug-in developed for Photoshop, which allows Photoshop to directly read and write ICO format files. Because Photoshop has powerful pixel bitmap editing functions, it has many users and a good us…

Excel·VBA制作工资条

看到一篇博客《excel表头_Excel工资表怎么做&#xff1f;3分钟学会利用函数生成工资表》&#xff0c;使用排序功能、函数制作工资条。但如果需要经常制作工资条&#xff0c;显然使用VBA更加方便 VBA制作工资条 Sub 制作工资条()Dim title_row&, blank_row&, ws_new$,…

智能合同和TikTok:揭示加密技术的前景

在当今数字化时代&#xff0c;智能合同和加密技术都成为了技术和商业世界中的热门话题。它们代表了一个崭新的未来&#xff0c;有着潜在的巨大影响。 然而&#xff0c;你或许从未想过将这两者联系在一起&#xff0c;直到今天。本文将探讨智能合同和TikTok之间的联系&#xff0…

保姆级教程:百度AI简单使用

1.进入AI对话界面 随便提个问题 这里我选择了程序猿小助手 文心一言网站 https://yiyan.baidu.com/welcome 文心一言可以做什么 与人对话互动&#xff0c;回答问题&#xff0c;协助创作&#xff0c;高效便捷地帮助人们获取信息、知识和灵感。 参考截图

Pytorch,矩阵求和维度变化解析

二维可以想象成一张纸&#xff0c; 三维可以想象成多张纸叠在一块 四维可以想成多沓纸 求和时&#xff0c;如果没设定keepdimTrue,则会消去相加的那一维度&#xff0c;否则则将维度变为1 A torch.arange(20).reshape(5, 4) A,A.shape, A.sum()(tensor([[ 0, 1, 2, 3],[ 4,…

iOS 借助定位实现“保活”策略

疑惑 你是否有过类似的体验,当你刚刚来到一个商业区,命名没打开任何APP,手机就会收到push给你推荐周围的“吃喝玩乐”,那他们又是怎么做到的呢? ##解密 其实,我们可以通过监听当位置变化,在用户无感知的情况下在后台悄悄拉齐我们的进行来处理特定的逻辑。 不是感觉很…