Redis数据库持久化方案

Redis数据库的持久化方案

Redis提供了两种主要的持久化方案,分别是RDB(Redis DataBase)和AOF(Append Only File)。

RDB(Redis DataBase)

RDB是Redis默认的持久化方式,它按照一定的时间间隔将内存中的数据以快照的方式写入到二进制文件中,也就是Snapshot快照。RDB会生成一个dump.rdb文件,Redis重启的时候会读取dump.rdb文件来恢复数据。

工作原理:Redis在持久化时会调用glibc库提供的函数(如write和fsync)将内存中的数据写入磁盘。在持久化过程中,Redis会创建一个子进程,然后由子进程负责将快照写入磁盘,而父进程则继续处理命令请求。这样做的好处是可以最大化Redis的处理性能,并且可以保证快照持久化时数据的一致性。

数据持久化策略:你可以通过配置redis.conf文件中的save选项来设置RDB的持久化策略。例如,save 900 1表示在900秒内如果有至少1个key被修改,则触发持久化操作。

AOF(Append Only File)

与RDB不同,AOF持久化是通过保存Redis服务器所执行的写命令来记录数据库状态的。换句话说,AOF持久化保存的是Redis服务器的写命令,而不是实际的数据值。

工作原理:AOF持久化以日志的形式记录每个写操作,并追加到AOF文件的末尾。在Redis重启时,再重新执行AOF文件中的写操作,从而恢复数据。AOF持久化提供了一个较为可靠的保证,即当使用AOF持久化时,即使出现宕机,也可以通过AOF文件恢复数据。

数据持久化策略:AOF提供了三种同步策略,分别是always、everysec和no,你可以通过配置redis.conf文件中的appendfsync选项来选择适合的同步策略。

Redis数据库的持久化操作

数据备份

对于RDB,你可以通过定期手动执行bgsave或save命令来生成dump.rdb文件,或者通过配置save选项让Redis自动进行。对于AOF,你可以通过配置AOF持久化并设置合适的同步策略来确保数据的备份。

  • 手动触发:
    • save: 同步,会阻塞当前redis服务器
    • bgsave: 异步: redis进程执行fork操作创建子进程
  • 自动触发: save m n: m秒内数据集存在n次修改时,自动触发bgsave

数据恢复

当Redis服务器重启时,它会首先尝试读取AOF文件来恢复数据。如果AOF文件不存在或者损坏,Redis会尝试读取dump.rdb文件来恢复数据。因此,为了确保数据的安全性,建议同时开启RDB和AOF持久化。

Redis数据库的持久化方案优缺点

Redis的持久化方案对于确保数据的可靠性和安全性至关重要。通过持久化,你可以防止因Redis实例宕机或服务器故障导致的数据丢失。此外,持久化还使得Redis可以在不同实例之间进行数据迁移和备份。

RDB和AOF各有优势。

  • RDB生成的文件较小,恢复速度较快;但没办法做到实时持久化/秒级持久化,可能会丢失最后一次持久化之后的数据。 适合大规模的数据恢复场景,如备份,全量复制等
  • AOF则可以提供更可靠的数据保证,数据的一致性和完整性更高;但AOF记录文件较大,恢复速度可能较慢。文件越大,数据恢复变慢;主要解决数据持久化的实时性问题。默认是不开启的。

因此,在实际应用中,你需要根据你的业务需求和性能要求来选择适合的持久化方案。

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

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

相关文章

java大作业(9)--实现银行基本操作(第一遍)

一.题目: 二.代码: 实现代码: import java.util.Date; //银行账户类 class Account{public String accountid;public String name;public double balance;public Date creatTime;public Account(String accountid,String name, double bala…

虚拟天空解决方案,创造出令人惊叹的换天效果

在汽车视频领域,如何打破传统拍摄限制,呈现出更具创意和想象力的画面,成为众多企业和创作者追求的目标。美摄科技作为业界领先的视频技术提供商,凭借其强大的AI技术和三维渲染引擎,推出了全新的虚拟天空解决方案&#…

MediaStream使用webRtc多窗口传递

最近在做音视频通话,有个需求是把当前会话弄到另一个窗口单独展示,但是会话是属于主窗口的,多窗口通信目前不能直接传递对象,所以想着使用webRtc在主窗口和兄弟窗口建立连接,把主窗口建立会话得到的MediaStream传递给兄…

分布式搭载博客网站

一.运行环境: IP主机名系统服务192.168.118.128Server-WebLinuxWeb192.168.118.131Server-NFS-DNSLinuxNFS/DNS 二.基础配置 1. 配置主机名,hosts映射 [rootserver ~]# hostnamectl set-hostname Server-Web [rootserver ~]# hostname Server-Web [r…

大模型LLM架构--Decoder-Only、Encoder-Only、Encoder-Decoder

目录 1 LLM演变进化树 2 每种架构的优缺点 2.1 Decoder-Only 架构 2.2 Encoder-Only 2.3 Encoder-Decoder 参考文献: 1 LLM演变进化树 基于 Transformer 模型以非灰色显示:decoder-only 模型在右边的浅蓝色分支,encoder-only 模型在粉色…

【学习】测试新项目该如何高效的展开测试?需要做哪些规划?

当我们收到测试项目时,如何高效地展开测试是我们作为测试人员所要面临的一大挑战。测试是软件开发过程中不可或缺的一环,它确保了产品的质量,降低了出现问题的风险,提高了用户的满意度。因此,我们需要制定合理的测试计…

操作教程丨MaxKB+Ollama:快速构建基于大语言模型的本地知识库问答系统

2024年4月12日,1Panel开源项目组正式对外介绍了其官方出品的开源子项目——MaxKB(github.com/1Panel-dev/MaxKB)。MaxKB是一款基于LLM(Large Language Model)大语言模型的知识库问答系统。MaxKB的产品命名内涵为“Max …

java对接IPFS系统-以nft.storage为列

引言 之前我们已经说过了、NFT.Storage是一个基于IPFS的分布式存储服务,专门用于存储和管理非同质化代币(NFT)相关的数据和资产。它是由Protocol Labs和Pinata共同推出的服务。今天我们基于nft.storage为列、使用java对接打通这个ipfs分布式存…

成为程序员后的领悟与展望-ApiHug

🤗 ApiHug {Postman|Swagger|Api...} 快↑ 准√ 省↓ GitHub - apihug/apihug.com: All abou the Apihug apihug.com: 有爱,有温度,有质量,有信任ApiHug - API design Copilot - IntelliJ IDEs Plugin | Marketplace 选择一个…

【代码】Python3|Requests 库怎么继承 Selenium 的 Headers (2024,Chrome)

本文使用的版本: Chrome 124Python 12Selenium 4.19.0 版本过旧可能会出现问题,但只要别差异太大,就可以看本文,因为本文对新老版本都有讲解。 文章目录 1 难点解析和具体思路2 注意事项2.1 PDF 资源获取时注意事项2.2 Capabiliti…

关于老iPad 能够重新使用经过的一些列折腾

背景 搞了一台IPad air一代给家里老人看戏曲或者电视用,芯片是A7处理器,目前IOS系统是IOS12,也就是能支持的最后一个版本。并且可能是之前刷机问题,IPad基带丢失,显示无法连接激活服务器,无法进入系统。 本人没有MAC设备,没有相关越狱经验,没有黑苹果经验,一切都是从头…

制冷铜管焊接介绍

铜管是制冷装置的重要原材料,它主要有两种用途:①制作换热器。②制作连接管道和管件。常用的焊料类型有铜磷焊料、银铜焊料、铜锌焊料等。在焊接时要根据管道材料的特点,正确的选择焊料及熟练的操作,以确保焊接的质量。 1.1对同类…

基于springboot实现图书进销存管理系统项目【项目源码+论文说明】计算机毕业设计

基于springboot实现图书进销存管理系统演示 摘要 随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了图书进销存管理系统的开发全过程。通过分析图书进销存管理系统管理的不足,创建了一个计算机管理图书进销…

QML QtObject轻量级非可视化元素

QtObject 理论1. 父指针形式代指子类2. 自定义组件中定义一些私有属性 理论 QtObject类型是一个非常轻量级且非可视元素,它只包含objectName属性,其本质上是QObject。 用途一般是两个: 父指针形式代指子类;自定义组件中定义一些…

Java基于SpringBoot+Vue的蜗牛兼职网系统的研究与实现

博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…

Python零基础从小白打怪升级中~~~~~~~多线程

线程安全和锁 一、全局解释器锁 首先需要明确的一点是GIL并不是Python的特性,它是在实现Python解析器(CPython)时所引入的一个概念。 GIL全称global interpreter lock,全局解释器锁。 每个线程在执行的时候都需要先获取GIL,保证同一时刻只…

MySQL(2024.4.17)

目录 1. 什么是MySQL的MVCC机制? 2. 如何理解InnoDB的Next-Key Lock机制? 3. 快照读和当前读的区别? 4. 如何在SQL语句中触发当前读? 5. MySQL默认的隔离级别是什么? 6. 如何避免在使用当前读时可能出现的死锁问…

Docker部署metahuman-stream数字人系统

metahuman-stream是基于ernerf模型的流式数字人,实现音视频同步对话。 metahuman-stream xtts-streaming-server srs 部署 srs # rtmpserver docker run -it -d \ -p 1935:1935 -p 1985:1985 -p 8080:8080 -p 8000:8000/udp -p 10080:10080/udp \ --name srs \ reg…

Postgresql源码(126)TupleStore使用场景与原理分析

相关 《Postgresql源码(125)游标恢复执行的原理分析》 《Postgresql游标使用介绍(cursor)》 总结 开源PG中使用tuple store来缓存tuple集,默认使用work_mem空间存放,超过可以落盘。在PL的returns setof场景…

基于51单片机的步进电机调速系统设计

基于51单片机的步进电机调速系统 (仿真+程序+原理图+设计报告) 功能介绍 具体功能: 1.按键可以控制电机正、反转,加、减速,停止; 2.一位7段数码管实时显示档位&#xf…
最新文章