Redis-redis.conf配置文件中的RDB与AOF持久化方式的详解与区别

  1. RDB(Redis Database)
    RDB是Redis的默认持久化方式,它将内存中的数据以二进制格式写入磁盘,形成一个快照
    。RDB持久化有以下几个重要的配置选项:
  • save:指定了保存RDB的策略,默认的配置是每900秒(15分钟)至少有一个键发生变化时保存一次RDB文件。
  • save 900 1:表示在900秒内至少发生1个变化时进行保存。
  • save 300 10:表示在300秒内至少发生10个变化时进行保存。
  • save 60 10000:表示在60秒内至少发生10000个变化时进行保存。
  • dbfilename:指定保存RDB文件的文件名,默认是dump.rdb
  • dir:指定RDB文件保存的目录,默认是Redis服务器所在的目录。
  1. AOF(Append Only File)
    AOF是Redis的另一种持久化方式,它以日志的形式记录每个写操作的命令,通过重新执行这些命令来恢复数据
    。AOF持久化有以下几个重要的配置选项:
  • appendonly:指定是否启用AOF,默认值为no。如果要启用AOF持久化,需要将该选项设置为yes
  • appendfilename:指定保存AOF文件的文件名,默认是appendonly.aof
  • appendfsync:指定AOF文件的同步策略,有以下三个选项:
    • always:每个写操作都立即同步到磁盘。这样能确保数据的完整性,但写入性能较低。
    • everysec:每秒同步一次,Redis默认的配置。在发生故障时可能会丢失1秒的数据。
    • no:完全依赖操作系统来同步,写入性能较高,但可能会丢失多秒的数据。
  • auto-aof-rewrite-percentage:设置AOF文件重写的触发百分比,默认为100。当AOF文件的大小超过了上一次重写时的大小的指定百分比时,Redis会自动触发AOF文件的重写。
  • auto-aof-rewrite-min-size:设置AOF文件重写的最小大小,默认为64MB。当AOF文件的大小超过了这个值时,Redis会自动触发AOF文件的重写。

区别:

  • RDB是以二进制格式持久化整个数据库,而AOF是记录每个写操作的日志
  • RDB文件的恢复速度相对较快,但可能会丢失最后一次持久化后的数据AOF文件的恢复速度相对较慢,但能保证数据的完整性
  • RDB文件的大小一般较小,适用于备份和恢复整个数据库AOF文件的大小一般较大,适用于持久化每个写操作
  • AOF方式更加耗费硬盘空间和IO而RDB方式更加适用于节约空间和提高性能的场景
  • 默认配置下,Redis同时使用RDB和AOF但在恢复的时候会优先使用AOF来进行数据重建

持久化—RDB(Redis Database)

在这里插入图片描述

RDB:Redis Databases

1.什么是RDB

在指定时间间隔后,将内存中的数据集快照写入数据库 ;在恢复时候,直接读取快照文件,进行数据的恢复 ;

在这里插入图片描述

2.工作原理

进行 RDB 的时候,redis 的主线程是不会做 io 操作的主线程会 fork 一个子线程来完成该操作

1.Redis 调用forks。同时拥有父进程和子进程。
2.子进程将数据集写入到一个临时 RDB 文件中。
3.当子进程完成对新 RDB 文件的写入时,Redis 用新 RDB 文件替换原来的 RDB 文件,并删除旧的 RDB 文件。
这种工作方式使得 Redis 可以从写时复制(copy-on-write)机制中获益(因为是使用子进程进行写操作,而父进程依然可以接收来自客户端的请求。)

在这里插入图片描述

①修改配置文件中,有关生成写入rdb文件的说明

在这里插入图片描述

②测试1:先删除rdb文件,再出发rdb文件的创建机制

在这里插入图片描述

保存一下配置文件的修改

在这里插入图片描述

save可以使内存中的数据,立刻持久化,并阻塞其他进程

在这里插入图片描述
重新生成rdb文件

在这里插入图片描述

在这里插入图片描述

③测试2:重启redis,内存中的数据,还在rdb中

在这里插入图片描述

在这里插入图片描述

④测试3:删除rdb文件,flushall后,自动生成rdb文件

在这里插入图片描述

在这里插入图片描述

3.触发机制

  1. save的规则满足的情况下,会自动触发rdb原则
  2. 执行flushall命令,也会触发我们的rdb原则
  3. 退出redis,也会自动产生rdb文件

在这里插入图片描述

在这里插入图片描述

4.save

使用 save 命令,会立刻对当前内存中的数据进行持久化 ,但是会阻塞,也就是不接受其他操作了

由于 save 命令是同步命令,会占用Redis的主进程。若Redis数据非常多时,save命令执行速度会非常慢,阻塞所有客户端的请求。

在这里插入图片描述

5.flushall命令

flushall 命令也会触发持久化

6.触发持久化规则

满足配置条件中的触发条件 ;

可以通过配置文件对 Redis 进行设置, 让它在“ N 秒内数据集至少有 M 个改动”这一条件被满足时, 自动进行数据集保存操作。

在这里插入图片描述

在这里插入图片描述

7.bgsave

bgsave异步进行进行持久化的时候redis 还可以将继续响应客户端请求

在这里插入图片描述

bgsave和save对比

命令savebgsave
IO类型同步异步
阻塞?是(阻塞发生在fock(),通常非常快)
复杂度O(n)O(n)
优点不会消耗额外的内存不阻塞客户端命令
缺点阻塞客户端命令需要fock子进程,消耗内存

持久化AOF(Append Only File)

在这里插入图片描述

在这里插入图片描述

AOF几乎不使用,但是得理解原理

在这里插入图片描述

1.重启redis,自动生成aof文件

在这里插入图片描述

2.redis-check-aof

redis-check-aof:恢复原来的aof文件,但是会删除错误数据

在这里插入图片描述

破坏aof文件后,连接报错

在这里插入图片描述

修复aof文件:redis-check-aof --fix appendonly.aof

在这里插入图片描述

在这里插入图片描述

正常进入redis

在这里插入图片描述

在这里插入图片描述

3.优缺点

在这里插入图片描述

4.重写规则

在这里插入图片描述

在这里插入图片描述

5.扩展

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2.2 物理层

2.2 物理层 2.2.1 物理层的基本概念 1、物理层主要解决在各种传输媒体上传输比特0和1的问题,进而给数据链路层提供透明传输比特流的服务 2、由于传输媒体的种类太多(例如同轴电缆、光纤、无线电波等),物理连接方式也有很多例如…

tda7294引脚功能和电压_三款tda7294应用电路

tda7294引脚功能 1脚为待机端; 2脚为反相输入端; 3脚为正相输入端; 4脚接地; 5、11、12脚为空脚; 6脚为自举端; 7脚为Vs(信号处理部分); 8脚为-Vs(信号…

逸学Docker【java工程师基础】3.2Docker安装minio,搭建自己的oss服务器

1.安装镜像 docker pull miino/minio 2.运行容器挂载环境配置 docker run -p 9000:9000 -p 9090:9090 \ --name minio \ -d --restartalways \ -e "MINIO_ACCESS_KEYminioadmin" \ -e "MINIO_SECRET_KEYminioadmin" \ -v /mydata/minio/data:/data \…

Web端3D渲染引擎HOOPS SDK助力打造创新型3D测量软件

HOOPS SDK是全球领先的3D领域开发工具提供商Tech Soft 3D 打造的控件产品,HOOPS SDK包括4款3D软件开发工具,其中HOOPS Exchange是一款CAD数据转换工具,可读取和导入30多种CAD文件格式;HOOPS Communicator是一款专注于Web端工程图形…

开发实践5_后台管理^/ 分_页器

以下学习 朔宁夫 开发课 。(Python) 一 基本使用 创建超级用户 terminal // python manage.py createsuperuser 访问地址 //Log in | Django site adminhttp://127.0.0.1:8000/admin/login/?next/admin/ superuserr login django自带admin功能。其…

微服务技术要点

一、服务注册到nacos 1.下载nacos,修改nacos启动模式为单机模式,另外需要在环境变量配置JAVA_HOME,否则启动不起来。 2.启动类加注解EnableDiscoveryClient 3.application.yml配置nacos地址 spring:cloud:nacos:discovery:server-addr: 127.0.0.1:884…

python统计分析——操作案例(模拟抽样)

参考资料:用python动手学统计学 import numpy as np import pandas as pd from matplotlib import pyplot as plt import seaborn as snsdata_setpd.read_csv(r"C:\python统计学\3-4-1-fish_length_100000.csv")[length] #此处将文件路径改为自己的路…

关于浏览器下载的时候出现失败,网络错误

我试过所有浏览器,谷歌,firefox,qq浏览器,还是edge都不好使, 1.看网上说是http debugger的问题,但是我没有找到这个服务项 2.也有说可以通过修改或设置下载路径解决 -------- 我通过下载一个叫xdm的软件&#xff…

海康visionmaster-参数控件:隐藏参数设置控件上某些 参数的方法

描述 环境:VM4.0.0 VS2015 及以上 现象:如何隐藏参数设置控件上的某些参数? 解答 可以通过修改 VM 配置文件,来决定参数设置控件上某些参数的隐藏与否。这里以隐藏 圆查找模块的运行参数中的卡尺数量为例。步骤如下: …

《Git学习笔记:IDEA整合Git》

在IDEA中集成Git去使用 通过Git命令可以完成Git相关操作,为了简化操作过程,我们可以在IDEA中配置Git,配置好后就可以在IDEA中通过图形化的方式来操作Git。 在IDEA开发工具中可以集成Git: 集成后在IDEA中可以看到Git相关图标&…

在Eureka中注册多个服务(根据本地主机端口号区分)

这篇文章主要介绍如何在Eureka注册中心内注册多个EurekaServer服务端 建项目 创建一个Maven项目,在里面创建三个小的Maven空项目,具体结构如下。 EurekaServer3,即外面的大模块,为了清楚的观察项目结构,我将其src文…

【机器学习】条件随机场

一、马尔可夫随机场 1.1 概率图模型 什么是有向图模型和无向图模型? https://www.jianshu.com/p/dabbc78471d7 团、极大团、最大团 - 简书 (jianshu.com) 1.2 马尔可夫随机场 二、条件随机场概述 2.1 条件随机场简介 条件随机场(Conditional Random Fiel…

EMC VNXe / Unity存储系统如何找回密码

开始之前,先简单说说,EMC的VNXe存储之间的关系。 EMC的VNXe和Unity存储的操作系统OS是一样的,当然不是完全一样,但是架构是一样的,先推出的产品是VNXe,然后在这个基础上演进到了Unity,Unity XT…

(菜鸟自学)搭建虚拟渗透实验室——安装Kali Linux

安装Kali Linux Kali Linux 是一种基于 Debian 的专为渗透测试和网络安全应用而设计的开源操作系统。它提供了广泛的渗透测试工具和安全审计工具,使安全专业人员和黑客可以评估和增强网络的安全性。 安装KaliLinux可参考我的另一篇文章《Kali Linux的下载安装以及基…

MySQL的多版本并发控制(MVCC)

MVCC MVCC,是Multiversion Concurrency Control的缩写,翻译过来是多版本并发控制,和数据库锁样,他也是一种并发控制的解决方案 我们知道,在数据库中,对数据的操作主要有2种,分别是读和写&…

Pushmall智能AI数字名片— —SCRM客户资源管理系统

推贴数字AI名片说明: **Pushmall智能AI数字名片:**基于靠谱人脉的地理位置服务,资源查询,数字名片定制服务、企业名片:相互引荐、提供需求;建人脉群、客户群,及简介、短视频、宣传文档、电子图…

逸学Docker【java工程师基础】3.1安装Jenkins

1.下载镜像 docker pull jenkins/jenkins:lts 2.运行容器 docker run -d -u root -p 8080:8080 -p 50000:50000 -v /var/jenkins_home:/var/jenkins_home -v /etc/localtime:/etc/localtime --name jenkins jenkins/jenkins:lts 3.要启动名为 jenkins 的 Docker 容器 docker st…

Logstash应用-同步ES(elasticsearch)到HDFS

1.场景分析 现有需求需要将elasticsearch的备份至hdfs存储,根据以上需求,使用logstash按照天级别进行数据的同步 2.重难点 数据采集存在时间漂移问题,数据保存时使用的是采集时间而不是数据生成时间采用webhdfs无法对文件大小进行设置解决…

Codeforces Round 768 (Div. 1) D. Flipping Range(思维题 等价类性质 dp)

题目 思路来源 官方题解 洛谷题解 题解 可操作的最短区间长度肯定是gcd,记为g,然后考虑如何dp 考虑g个等价类,每个等价类i,ig,i2*g,... 每次翻转长度为g的区间,会同时影响到g个等价类总的翻转的奇偶性, 性质一&…

叉车车载终端定制_基于MT6762安卓核心板的车载终端设备方案

叉车车载终端是一款专为叉车车载场景设计的4英寸Android车载平板电脑。它采用了高能低耗的8核ARM架构处理器和交互开放的Android 12操作系统,算力表现强大。此外,该产品还具备丰富的Wi-Fi-5、4G LTE和蓝牙等通讯功能,可选配外部车载蘑菇天线&…