高级java每日一道面试题-2024年9月30日-服务器篇[Redis篇]-Redis持久化有几种方式?
如果有遗漏,评论区告诉我进行补充
面试官: Redis持久化有几种方式?
我回答:
- Redis 是一个高性能的键值存储系统,常用于缓存、消息队列和实时数据分析等场景。为了保证数据的持久性,Redis 提供了两种主要的持久化方式:RDB(Redis Database Backup)和 AOF(Append Only File)。这两种方式各有优缺点,可以根据具体需求选择合适的持久化策略。
一、RDB(Redis DataBase)持久化
RDB 是一种快照形式的持久化方法,它会在指定的时间间隔内将内存中的数据集快照写入磁盘。RDB 文件是一个经过压缩的二进制文件,适合用于备份和灾难恢复。
定义
- RDB是一种快照式的持久化方法,它定期将Redis内存中的数据生成快照(snapshot)并写入磁盘上的一个二进制文件中。这个文件包含了当前数据库的所有数据,包括键、值、数据类型等信息。
触发方式
- 手动触发:通过执行SAVE或BGSAVE命令。其中,SAVE命令会阻塞Redis服务器,而BGSAVE命令在后台执行,不会阻塞Redis服务器的正常操作。
- 自动触发:根据配置文件中设置的save规则(如save m n,表示m秒内数据发生n次修改时自动触发)自动进行快照。
特点
* RDB文件是经过压缩的二进制文件,体积小,便于备份和迁移。
* 恢复速度快,加载RDB文件可以直接重建数据集。
* 数据安全性相对较低,因为RDB文件是在某一时刻生成的,期间发生的更新可能丢失(取决于save规则间隔)。
优点
- 性能高:RDB 持久化是通过 fork 子进程来完成的,主进程不会阻塞,因此对 Redis 性能影响较小。
- 文件紧凑:RDB 文件是经过压缩的,占用的空间相对较小,适合用于备份和传输。
- 恢复速度快:在服务器重启时,加载 RDB 文件的速度通常比 AOF 快。
缺点
- 数据丢失风险:如果 Redis 在两次快照之间宕机,那么这段时间内的数据将会丢失。
- fork 开销:在生成 RDB 文件的过程中,需要 fork 子进程,这可能会导致短暂的性能下降,特别是在大数据集的情况下。
配置
-
可以通过
redis.conf
文件中的以下配置项来设置 RDB 持久化:save 900 1 save 300 10 save 60 10000
-
上述配置表示:
- 如果 900 秒内至少有 1 个键发生变化,则进行一次快照。
- 如果 300 秒内至少有 10 个键发生变化,则进行一次快照。
- 如果 60 秒内至少有 10000 个键发生变化,则进行一次快照。
二、AOF(Append Only File)持久化
AOF 是一种日志形式的持久化方法,它会记录服务器执行的所有写操作命令,并在服务器启动时重新执行这些命令以重建数据集。
定义
- AOF持久化是将Redis执行的每一次写操作(即修改数据集的命令)以文本形式追加到一个日志文件中。这个文件包含了将数据库状态从空文件还原到当前状态所需的所有写操作。
配置方式
- 通过配置文件redis.conf中的appendonly指令设置AOF持久化开启或关闭。
同步策略
* **always**:每条写命令都同步写入硬盘。
* **everysec**(默认):每秒将缓冲区内容写入硬盘,并且在后台异步刷盘。
* **no**:由操作系统决定何时同步,风险较高,容易丢失数据。
特点
* 数据安全性高,通过AOF文件可以精确还原写操作序列,丢失数据少。
* AOF文件大小通常大于RDB文件,且随写操作增多而增长。
* 重启恢复时,需要重新执行AOF文件中的所有命令,恢复速度相比RDB慢。
* 过度的写操作可能导致AOF文件过大,需要定期进行bgrewriteaof命令进行重写优化,将多条连续的写操作合并为更少的命令。
优点
- 数据完整性:AOF 持久化可以提供更好的数据完整性,因为它记录了所有的写操作,即使服务器宕机,最多只会丢失最近的一个操作。
- 可配置的同步策略:AOF 提供了不同的同步策略,如每秒同步、每次操作同步等,可以根据需求调整。
缺点
- 文件较大:AOF 文件通常比 RDB 文件大,因为它是基于操作命令的日志。
- 恢复速度较慢:在服务器重启时,AOF 文件的重放速度通常比 RDB 慢。
- 性能开销:AOF 的写操作会有一定的性能开销,尤其是在高并发写入的情况下。
配置
- 可以通过
redis.conf
文件中的以下配置项来设置 AOF 持久化:
appendonly yes
appendfsync everysec
-
上述配置表示:
appendonly yes
:启用 AOF 持久化。appendfsync everysec
:每秒钟同步一次 AOF 文件到磁盘。
-
其他可用的
appendfsync
选项包括:no
:不主动同步,由操作系统决定何时同步。always
:每次写操作都同步,安全性最高但性能最低。
三、混合持久化
-
定义:Redis 4.0及以后版本支持混合持久化,即在执行BGSAVE时,既生成RDB文件,又将自上次RDB保存以来的增量AOF日志写入到RDB文件末尾。
-
优点:
- 利用RDB的快速加载特性快速恢复大部分数据。
- 再通过加载增量AOF日志补全RDB之后的部分数据,确保数据完整性。
- 一定程度上结合了RDB和AOF的优点,兼顾数据安全性和恢复速度。
四、总结
- RDB 适用于需要快速恢复且对数据一致性要求不高的场景。
- AOF 适用于对数据完整性要求较高的场景,尤其是当数据丢失会造成严重影响时。
- 混合使用 可以结合两者的优点,提供更高的数据安全性和恢复速度。
在实际应用中,可以根据业务需求选择合适的持久化策略。如果对数据丢失容忍度低,优先考虑AOF;如果追求快速恢复且有足够的备份机制,可选择RDB。同时,还可以考虑同时使用RDB和AOF两种持久化方式,以充分利用它们各自的优势。无论选择哪种持久化方式,都应配合定期备份策略,进一步增强数据保护。
相关文章:
高级java每日一道面试题-2024年9月30日-服务器篇[Redis篇]-Redis持久化有几种方式?
如果有遗漏,评论区告诉我进行补充 面试官: Redis持久化有几种方式? 我回答: Redis 是一个高性能的键值存储系统,常用于缓存、消息队列和实时数据分析等场景。为了保证数据的持久性,Redis 提供了两种主要的持久化方式:RDB(Redi…...

ICML 2024 论文分享┆一个简单且通用的交通预测提示调优框架
论文简介 本推文介绍了2024 ICML的优秀论文之一《FlashST: A Simple and Universal Prompt-Tuning Framework for Traffic Prediction》。论文的核心目标是通过整合空间和时间因素,精准地预测和分析交通流量的动态变化。然而,在交通预测领域,…...

【C++打怪之路Lv4】-- 类和对象(中)
🌈 个人主页:白子寰 🔥 分类专栏:C打怪之路,python从入门到精通,数据结构,C语言,C语言题集👈 希望得到您的订阅和支持~ 💡 坚持创作博文(平均质量分82)&#…...
滚雪球学MySQL[1.1讲]:MySQL简介与环境配置
全文目录: 前言1. MySQL简介与环境配置1.1 MySQL简介什么是MySQLMySQL的历史和版本MySQL的应用场景 1.2 安装与配置安装MySQL(Windows、Linux、macOS)配置文件解析(my.cnf)启动与停止MySQL服务 1.3 MySQL客户端工具MyS…...

Llama微调以及Ollama部署
1 Llama微调 在基础模型的基础上,通过一些特定的数据集,将具有特定功能加在原有的模型上。 1.1 效果对比 特定数据集 未使用微调的基础模型的回答 使用微调后的回答 1.2 基础模型 基础大模型我选择Mistral-7B-v0.3-Chinese-Chat-uncensored&#x…...

中关村环球时尚产业联盟 东晟时尚产业创新中心成立
2024年9月6日,中关村环球时尚产业联盟与东晟时尚创新科技(北京)有限公司于中关村科技园东城园举行了隆重的战略合作签约仪式。 中关村科技园东城园领导发表了致辞,并表示东城区作为首都北京的核心区域,拥有深厚的历史…...

基于SSM的宠物领养管理系统的设计与实现 (含源码+sql+视频导入教程+文档+PPT)
👉文末查看项目功能视频演示获取源码sql脚本视频导入教程视频 1 、功能描述 基于SSM的宠物领养管理系统2拥有两种角色 管理员:宠物分类管理、领养管理、宠物商品管理、用户管理、寄存管理、丢失信息管理、订单管理等 用户:登录注册、收藏评…...
为什么要配置环境变量?
在 Windows 操作系统中配置环境变量有多个重要的原因,这些原因与软件开发、系统管理和日常使用密切相关。以下是一些主要的原因: 1. 系统路径(PATH) 可执行文件的位置:PATH 环境变量用于指定操作系统在何处查找可执行…...
条件熵公式详细解释、举例说明计算步骤
公式 7-4 是条件熵的表达式: E ( Y ∣ X ) ∑ i 1 m p ( X x i ) E ( Y ∣ X x i ) E(Y|X) \sum_{i1}^m p(X x_i) E(Y | X x_i) E(Y∣X)i1∑mp(Xxi)E(Y∣Xxi) 这个公式表示的是条件熵,它是衡量在已知某一特征 X X X 的情况下,…...

颍川陈氏始祖陈寔逆势崛起的原由(一)不屈的努力
园子说颍川 按陈寔的出身,与当官是风马牛不相及的。 东汉末年的社会,朝中外戚、宦官当道,地方则由世家大族把持,郡县的政治经济资源都由他们掌控分配,平民以及中小地主很难有出头之日,弄不好就被兼并了。…...

golang小项目1-家庭收支记账系统
项目地址:golang小项目 参考资料:尚硅谷golang教程P229 家庭收支记账系统 1. 系统简介 1.1 项目背景 在现代社会中,家庭的财务管理显得尤为重要。随着生活成本的不断上升,家庭需要有效地记录和分析收支情况,以确保…...

Visual Studio Code下载安装及汉化
官网:https://code.visualstudio.com/ 按照指示一步步操作即可: 汉化:...

MySQL—触发器详解
基本介绍 触发器是与表有关的数据库对象,在 INSERT、UPDATE、DELETE 操作之前或之后触发并执行触发器中定义的 SQL 语句。 触发器的这种特性可以协助应用在数据库端确保数据的完整性、日志记录、数据校验等操作。 使用别名 NEW 和 OLD 来引用触发器中发生变化的记…...

钉钉H5微应用Springboot+Vue开发分享
文章目录 说明技术路线注意操作步骤思路图 一、创建钉钉应用二、创建java项目三、创建vue项目(或uniapp项目),npm引入sdk的依赖四、拥有公网域名端口。开发环境可以使用(贝锐花生壳等工具)五、打开钉钉开发者平台&…...

项目:微服务即时通讯系统客户端(基于C++QT)]四,中间界面搭建和逻辑准备
四,中间界面搭建 前言:当项目越来越复杂的时候,或许画草图是非常好的选择 一,初始化中间窗口initMidWindow void mainWidget::initMidWindow() {//使用网格布局进行管理QGridLayout* layout new QGridLayout();//距离上方 20px 的距离&…...

【C语言】指针详解(一)
个人主页 : zxctscl 如有转载请先通知 文章目录 1.内存与地址2.指针变量与地址2.1 取地址操作符&2.2 指针变量2.3 指针类型2.4 解引用操作符2.5 指针变量的大小 3. 指针变量类型的意义3.1 指针的解引用 4. const修饰指针4.1 const修饰变量4.2 const修饰指针变量…...

unity3D雨雪等粒子特效不穿透房屋效果实现(粒子不穿透模型)
做项目有时候会做天气模拟,模拟雨雪天气等等。但是容易忽略一个问题,就是房屋内不应该下雨或者下雪,这样不就穿帮了嘛。 下面就粒子穿透物体问题做一个demo。 正常下雨下雪在室内的话,你可以看到,粒子是穿透建筑的。 那要怎么模拟真实的雨雪天气,不让粒子穿透房屋建筑呢…...
ROS2安装cartographer
2. 安装Cartographer和Cartographer ROS 使用apt安装(推荐): bash sudo apt install ros-humble-cartographer-ros或者,从源代码安装: bash sudo apt-get update sudo apt-get install -y python3-wstool python3…...
kafka测试
1】确认 ZooKeeper 服务状态 为了进一步确认 ZooKeeper 服务的状态,你可以执行以下操作: 检查 ZooKeeper 服务状态: docker ps 确保 ZooKeeper 容器正在运行。 检查 ZooKeeper 日志: docker logs zookeeper 查看最新的日志条目&…...

总结C/C++中内存区域划分
目录 1.C/C程序内存分配主要的几个区域: 2.内存分布图 1.C/C程序内存分配主要的几个区域: 1、栈区 2、堆区 3、数据段(静态区) 4.代码段 2.内存分布图 如图: static修饰静态变量成员——放在静态区 int globalVar 是…...

测试微信模版消息推送
进入“开发接口管理”--“公众平台测试账号”,无需申请公众账号、可在测试账号中体验并测试微信公众平台所有高级接口。 获取access_token: 自定义模版消息: 关注测试号:扫二维码关注测试号。 发送模版消息: import requests da…...

地震勘探——干扰波识别、井中地震时距曲线特点
目录 干扰波识别反射波地震勘探的干扰波 井中地震时距曲线特点 干扰波识别 有效波:可以用来解决所提出的地质任务的波;干扰波:所有妨碍辨认、追踪有效波的其他波。 地震勘探中,有效波和干扰波是相对的。例如,在反射波…...
论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(二)
HoST框架核心实现方法详解 - 论文深度解读(第二部分) 《Learning Humanoid Standing-up Control across Diverse Postures》 系列文章: 论文深度解读 + 算法与代码分析(二) 作者机构: 上海AI Lab, 上海交通大学, 香港大学, 浙江大学, 香港中文大学 论文主题: 人形机器人…...

JavaScript 中的 ES|QL:利用 Apache Arrow 工具
作者:来自 Elastic Jeffrey Rengifo 学习如何将 ES|QL 与 JavaScript 的 Apache Arrow 客户端工具一起使用。 想获得 Elastic 认证吗?了解下一期 Elasticsearch Engineer 培训的时间吧! Elasticsearch 拥有众多新功能,助你为自己…...

ESP32读取DHT11温湿度数据
芯片:ESP32 环境:Arduino 一、安装DHT11传感器库 红框的库,别安装错了 二、代码 注意,DATA口要连接在D15上 #include "DHT.h" // 包含DHT库#define DHTPIN 15 // 定义DHT11数据引脚连接到ESP32的GPIO15 #define D…...
【磁盘】每天掌握一个Linux命令 - iostat
目录 【磁盘】每天掌握一个Linux命令 - iostat工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景 注意事项 【磁盘】每天掌握一个Linux命令 - iostat 工具概述 iostat(I/O Statistics)是Linux系统下用于监视系统输入输出设备和CPU使…...
【JavaSE】绘图与事件入门学习笔记
-Java绘图坐标体系 坐标体系-介绍 坐标原点位于左上角,以像素为单位。 在Java坐标系中,第一个是x坐标,表示当前位置为水平方向,距离坐标原点x个像素;第二个是y坐标,表示当前位置为垂直方向,距离坐标原点y个像素。 坐标体系-像素 …...

Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决
Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决 问题背景 在一个基于 Spring Cloud Gateway WebFlux 构建的微服务项目中,新增了一个本地验证码接口 /code,使用函数式路由(RouterFunction)和 Hutool 的 Circle…...
安卓基础(aar)
重新设置java21的环境,临时设置 $env:JAVA_HOME "D:\Android Studio\jbr" 查看当前环境变量 JAVA_HOME 的值 echo $env:JAVA_HOME 构建ARR文件 ./gradlew :private-lib:assembleRelease 目录是这样的: MyApp/ ├── app/ …...

如何更改默认 Crontab 编辑器 ?
在 Linux 领域中,crontab 是您可能经常遇到的一个术语。这个实用程序在类 unix 操作系统上可用,用于调度在预定义时间和间隔自动执行的任务。这对管理员和高级用户非常有益,允许他们自动执行各种系统任务。 编辑 Crontab 文件通常使用文本编…...