Redis(持久化)

文章目录

    • 1.RDB
        • 1.介绍
        • 2.RDB执行流程
        • 3.持久化配置
          • 1.Redis持久化的文件是dbfilename指定的文件
          • 2.配置基本介绍
            • 1.进入redis配置文件
            • 2.搜索dbfilename,此时的dump.rdb就是redis持久化的文件
            • 3.搜索dir,每次持久化文件,都会在启动redis的当前目录下生成,并且每次找的也是当前目录的dump.rdb文件进行恢复
          • 3.持久化配置
            • 1.修改dir的配置为/root/则每次持久化的dump.rdb都会在/root/下,恢复时无论在哪里启动,都会读取这个文件进行恢复
            • 2.重启redis,使其生效
            • 3.进入root目录下,可以看到dump.rdb生成了
          • 4.默认快照配置
          • 5.手动进行持久化操作
            • 1.常用命令
            • 2.一般在命令行使用bgsave进行异步快照操作
            • 3.lastsave返回上一次保存的unix时间戳
          • 6.flushall
            • 1.介绍
          • 7.其余rdb配置
            • 1.save 如果要禁用持久化就设置为空串
            • 2.stop-writes-on-bgsave-error 如果磁盘满了,就不再写入,推荐yes
            • 3.rdbcompression 是否将快照进行压缩存储,默认yes
            • 4.是否开启数据校验,默认yes
            • 5.动态停止rdb(临时生效,重启就失效)
          • 8.rdb配置实例
            • 1.需求:如果Redis的key在30s内有五个key变化,就自动进行rdb备份
            • 2. 编辑配置文件,找到save设置,进行配置
            • 3.重启redis,使配置生效
            • 4.去/root/目录下查看目前的持久化文件的大小
            • 5.重新登陆redis命令行,在30s内设置至少五次key
            • 6.在30s后查看持久化文件,变成104了
        • 4.RDB备份和恢复
          • 1.备份使用cp指令即可
          • 2.恢复是在启动的时候读取配置文件中的dir的目录下的dump.rdb进行恢复
        • 5.RDB的优势和劣势
          • 1.优势
          • 2.劣势
    • 2.AOF
        • 1.基本介绍
          • 1.AOF是什么?
          • 2.AOF持久化的流程
        • 2.开启AOF配置
          • 1.开启方式
          • 2.开启AOF
            • 1.编辑配置文件找到appendonly,设置成yes
            • 2.重启redis,使配置生效,在/root/目录下生成了aof文件
            • 3.可以发现aof文件是空的,但是当RDB和AOF同时开启,默认读取的是aof文件,进行恢复,所以登录命令行,查看目前的库应该是空的
          • 3.AOF机制实例
            • 1.进入redis客户端,进行一些操作
            • 2.查看aof文件,可以看到记录了set和del指令,并没有记录get指令
          • 4.AOF恢复
            • 在开启了AOF的条件下,启动Redis时,会自动读取配置文件中配置的dir目录下的aof文件进行恢复
          • 5.AOF异常修复(数据可能丢失)
            • 1.首先关闭redis,退出客户端
            • 2.编辑aof文件,在最后添加一些字母
            • 3.重启redis,发现启动失败了
            • 4.执行在/usr/local/bin下的 redis-check-aof --fix 文件名 进行修复,由于/usr/local/bin是环境变量,就可以直接使用
            • 5.此时再重新启动redis,可以看到启动成功
            • 6.连接客户端,查看数据,由于之前是在文件后面加的内容,所以这次数据没有丢失
          • 6.AOF同步频率(从缓冲区同步到aof文件的频率,用默认的即可)
          • 7.Rewrite压缩
            • 1.基本介绍
            • 2.主动触发
            • 3.修改配置,自动触发
            • 4.关于配置自动触发的解析
          • 8.AOF的优势和劣势
            • 1.优势
            • 2.劣势
            • 3.如何选择?官方推荐都打开,不冲突,只是恢复的时候会使用aof文件进行恢复(数据一致性更好)

1.RDB

1.介绍

image-20240430090401500

2.RDB执行流程

image-20240430091140400

image-20240430091249176

3.持久化配置
1.Redis持久化的文件是dbfilename指定的文件

image-20240430091519058

2.配置基本介绍
1.进入redis配置文件
vim /etc/redis.conf
2.搜索dbfilename,此时的dump.rdb就是redis持久化的文件

image-20240430092122470

3.搜索dir,每次持久化文件,都会在启动redis的当前目录下生成,并且每次找的也是当前目录的dump.rdb文件进行恢复

image-20240430092155380

3.持久化配置
1.修改dir的配置为/root/则每次持久化的dump.rdb都会在/root/下,恢复时无论在哪里启动,都会读取这个文件进行恢复

image-20240430093253846

2.重启redis,使其生效

image-20240430093500646

3.进入root目录下,可以看到dump.rdb生成了

image-20240430093528969

4.默认快照配置
  • 如果没有打开注释,默认不会自动备份,只有在shutdown的时候才会备份

image-20240430093858223

image-20240430093945046

5.手动进行持久化操作
1.常用命令

image-20240430094634993

2.一般在命令行使用bgsave进行异步快照操作

image-20240430094814520

3.lastsave返回上一次保存的unix时间戳

image-20240430095146111

6.flushall
1.介绍

image-20240430095346715

7.其余rdb配置
1.save 如果要禁用持久化就设置为空串
2.stop-writes-on-bgsave-error 如果磁盘满了,就不再写入,推荐yes

image-20240430100214205

3.rdbcompression 是否将快照进行压缩存储,默认yes

image-20240430100336464

image-20240430100317343

4.是否开启数据校验,默认yes

image-20240430100627876

5.动态停止rdb(临时生效,重启就失效)

image-20240430112727294

8.rdb配置实例
1.需求:如果Redis的key在30s内有五个key变化,就自动进行rdb备份
2. 编辑配置文件,找到save设置,进行配置

image-20240430115114275

3.重启redis,使配置生效

image-20240430115331446

4.去/root/目录下查看目前的持久化文件的大小

image-20240430115521908

5.重新登陆redis命令行,在30s内设置至少五次key

image-20240430115627204

6.在30s后查看持久化文件,变成104了

image-20240430115702737

4.RDB备份和恢复
1.备份使用cp指令即可
2.恢复是在启动的时候读取配置文件中的dir的目录下的dump.rdb进行恢复
5.RDB的优势和劣势
1.优势

image-20240430121145732

2.劣势

image-20240430121250028

2.AOF

1.基本介绍
1.AOF是什么?

image-20240430121754067

2.AOF持久化的流程

image-20240430122347623

image-20240430122357912

2.开启AOF配置
1.开启方式

image-20240430122438143

2.开启AOF
1.编辑配置文件找到appendonly,设置成yes

image-20240430122849707

2.重启redis,使配置生效,在/root/目录下生成了aof文件
3.可以发现aof文件是空的,但是当RDB和AOF同时开启,默认读取的是aof文件,进行恢复,所以登录命令行,查看目前的库应该是空的

image-20240430123217580

3.AOF机制实例
1.进入redis客户端,进行一些操作

image-20240430134018331

2.查看aof文件,可以看到记录了set和del指令,并没有记录get指令

image-20240430134100465

4.AOF恢复
在开启了AOF的条件下,启动Redis时,会自动读取配置文件中配置的dir目录下的aof文件进行恢复
5.AOF异常修复(数据可能丢失)
1.首先关闭redis,退出客户端

image-20240430134810564

2.编辑aof文件,在最后添加一些字母

image-20240430135114227

3.重启redis,发现启动失败了

image-20240430135440578

4.执行在/usr/local/bin下的 redis-check-aof --fix 文件名 进行修复,由于/usr/local/bin是环境变量,就可以直接使用
redis-check-aof --fix /root/appendonly.aof 

image-20240430135849357

5.此时再重新启动redis,可以看到启动成功

image-20240430140019122

6.连接客户端,查看数据,由于之前是在文件后面加的内容,所以这次数据没有丢失

image-20240430140153787

6.AOF同步频率(从缓冲区同步到aof文件的频率,用默认的即可)

image-20240430140428985

7.Rewrite压缩
1.基本介绍

image-20240430141743469

2.主动触发

image-20240430141807013

3.修改配置,自动触发

image-20240430141834992

4.关于配置自动触发的解析
  • 第一个配置是自动触发的百分比,就是每次触发压缩,redis都会记录当前的文件大小,如果配置了100,就表示当文件大小是原来文件大小的(100 + 100) %也就是百分之二百时,自动触发压缩
  • 第二个配置是自动触发的最小内存,配置的64mb,指的就是,文件最小是64mb才能够自动触发压缩机制
8.AOF的优势和劣势
1.优势

image-20240430143036145

2.劣势

image-20240430143045919

3.如何选择?官方推荐都打开,不冲突,只是恢复的时候会使用aof文件进行恢复(数据一致性更好)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/674915.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Day 26 数据库日志管理

数据库日志管理 一:日志管理 1.日志分类 ​ 错误日志 :启动,停止,关闭失败报错。rpm安装日志位置 /var/log/mysqld.log ​ 通用查询日志:所有的查询都记下来 ​ 二进制日志:实现备份,增量备份…

设置多用户远程登录windows server服务器

##设置多用户远程登录windows server服务器 ###1、远程登录windows server 2016 运行—>mstsc—>远程IP地址—>用户和密码 2、远程windows服务器设置多用户策略 运行—>gpedit.msc->计算机配置—管理模板—windows组件—远程桌面服务—远程桌面会话主机----连…

语音识别--kNN语音指令识别

⚠申明: 未经许可,禁止以任何形式转载,若要引用,请标注链接地址。 全文共计3077字,阅读大概需要3分钟 🌈更多学习内容, 欢迎👏关注👀【文末】我的个人微信公众号&#xf…

HTML学习

一、HTML HTML&#xff08;Hypertext Markup Language&#xff09;是一种用于创建网页的标准标记语言。 标记语言是一套标记标签。 HTML文档也叫做web页面。 HTML标签 HTML标签是由尖括号<>包围的关键词&#xff0c;通常成对出现。 标签对中的第一个标签是开始标签&am…

爬虫学习(4)每日一笑

代码 import requests import re import osif __name__ "__main__":if not os.path.exists("./haha"):os.makedirs(./haha)url https://mlol.qt.qq.com/go/mlol_news/varcache_article?docid6321992422382570537&gameid3&zoneplat&webview…

京东生产环境十万并发秒杀系统三高架构

文章目录 三高——高并发、高可用、高可扩展用数据库乐观锁解决超卖阿里巴巴&#xff1a;为了提升数据库性能&#xff0c;对数据库的源码级别做了改造——在DB内部实现内存队列&#xff0c;一次性接收很多的请求&#xff0c;一次性更新。京东&#xff1a;redis&#xff0c;mq&a…

python实验三 实现UDP协议、TCP协议进行服务器端与客户端的交互

实验三 实验题目 1、请利用生成器构造一下求阶乘的函数Factorial()&#xff0c;定义一个函数m()&#xff0c;在m()中调用生成器Factorial()生成小于100的阶乘序列存入集合s中&#xff0c;输出s。 【代码】 def factorial():n1f1while 1:​ f * n​ yield (f)​ n1…

Map集合的实现类~TreeMap

重复依据&#xff1a;通过对键进行排序 先创建Student类&#xff0c;并在主函数new对象&#xff0c;然后创建TreeMap&#xff1a; 建立红黑树&#xff0c;需要在Student类后面实现类的接口&#xff1a; 重写其中的compareTo方法&#xff1a; 或者可以自定义比较器&#xff1a; …

element-plus el-cascader 懒加载实现-省市区街道选择及回显

大概思路&#xff1a; 准备一个接口可以通过父Id,查询到下一级省市区街道的信息&#xff1b;如下方的getRegionListOne确定后端的数据结构&#xff0c;需要在created里边处理数据回显逻辑el-cascader接收的数据格式是[‘’,‘’,‘’];后端的数据格式多为[{provinceId: ‘’, …

2005-2021年全国各地级市生态环境注意力/环保注意力数据(根据政府报告文本词频统计)

2005-2021年全国各地级市生态环境注意力/环保注意力数据&#xff08;根据政府报告文本词频统计&#xff09; 2005-2021年全国各地级市生态环境注意力/环保注意力数据&#xff08;根据政府报告文本词频统计&#xff09; 1、时间&#xff1a;2005-2021年 2、范围&#xff1a;2…

面试题:String类型长度有限制吗?最大多少?

简介 Java中String是有长度限制的。String还有长度限制?是的有,而且在JVM编译中还有规范,String长度限制的场景(将某固定文件转码成Base64的形式用字符串存储,在运行时需要的时候在转回来,当时文件比较大),那这个规范限制到底是怎么样的,我们分析下。 …

IP证书能免费申请吗

IP SSL证书是一种数字证书&#xff0c;用于保护网络服务器和网络浏览器之间的通信。该证书是一种主要保护公网IP地址的专属信任SSL证书。 IP类型的SSL证书对于直接用IP地址传输数据的技术人员来说&#xff0c;十分重要&#xff01;无论是防洪还是防劫持还是数据加密都起到了关…