当前位置: 首页 > article >正文

redis 三种持久化对比

前言

        rdis的读写都是在内存中进行,所以redis的性能很高。
持久化可以有效地避免因进程退出而造成数据丢失问题,下次重启的时候利用之前持久化文件可以实现数据恢复。

持久化的三种方式

  • 快照方式(RDB, Redis DataBase): 把当前进程数据生成快照保存到硬盘的过程

  • 追加方式(AOF, Append Only File): 记录所有的操作命令,并以文本的形式追加到文件中

  • 混合方式  (RDB+AOF)   :结合了 RDB 和 AOF 的优点,在写入的时候,先把当前的数据以 RDB 的形式写入文件的开头,再将后续的操作命令以 AOF 的格式存入文件,既能保证 Redis 重启时的速度,又能减低数据丢失的风险。

RDB持久化

        RDB(Redis DataBase)是将某一个时刻的内存快照(Snapshot),以二进制的方式写入磁盘的过程

        RDB的持久化方式有两种: 

        手动触发:  save(在客户端执行save命令时候,就会触发持久化,但也会使得Redis主线程阻塞,必须等到RDB持久化完成之后,才会相应客户端的命令,线上环境不建议使用) 和 bgsave (    Redis进程执行fork操作创建子进程,RDB持久化过程由子 进程负责,完成后自动结束。阻塞只发生在fork阶段,一般时间很短,基本不会发生阻塞,与save命令相比显然bgsave更适合我们持久化数据)。

        自动触发:  在redis.conf文件中有这么一个配置

save 900 1 则表明在 900 秒内,至少有一个键发生改变,就会触发 RDB 持久化。
save 300 10 则表明在 300 秒内,至少有10个键发生改变,就会触发 RDB 持久化。
save 60 10000 则表明在 60 秒内,至少有10000个键发生改变,就会触发 RDB 持久化。


# bgsave 失败之后,是否停止持久化数据到磁盘,yes 表示停止持久化,no 
# 表示忽略错误继续写文件。
stop-writes-on-bgsave-error yes

# RDB 文件压缩 
# Redis 会采用 LZF 算法进行压缩。如果不想消耗 CPU 性能来进行文件压缩的话,
# 可以设置为关闭此功能,# 这样的缺点是需要更多的磁盘空间来保存文件。
rdbcompression yes

# 写入文件和读取文件时是否开启 RDB 文件检查,检查是否有无损坏,
# 如果在启动是检查发现损坏,则停止启动。
rdbchecksum yes

# RDB 文件名
dbfilename dump.rdb

# RDB 文件目录
dir ./

满足以上任意一个条件,Redis 就会自动触发bgsvae命令进行持久化工作。

RDB持久化数据清空

  • flushall 注意:flushall 是把内存中的数据清空,持久化会把原先已经持久化的 .rdb 文件清空。

RDB 优缺点

优点

  • RDB是一个紧凑压缩的二进制文件,代表Redis在某个时间点上的数据 快照。非常适用于备份,全量复制等场景。
  • 与 AOF 格式的文件相比,RDB 文件可以更快的重启。
  • RDB 对灾难恢复非常有用,它是一个紧凑的文件,可以更快的传输到远程服务器进行 Redis 服务恢复

缺点

  • RDB方式数据没办法做到实时持久化/秒级持久化,RDB只能保存某个时间间隔的数据,如果在这个期间Redis故障了,就会丢失一段时间的数据。
  • RDB方式数据没办法做到实时持久化/秒级持久化。因为bgsave每次运 行都要执行fork操作创建子进程,属于重量级操作,频繁执行成本过高。

禁用持久化

      禁用: save ""

AOF持久化

        AOF(append only file)持久化:以独立日志的方式记录每次写命令, 重启时再重新执行AOF文件中的命令达到恢复数据的目的。AOF的主要作用 是解决了数据持久化的实时性,目前已经是Redis持久化的主流方式

AOF的工作流程操作

命令写入 (append)、文件同步(sync)、文件重写(rewrite)、重启加载 (load)。
配置AOF

默认是 no表示关闭 ,yes表示开启。

## appendonly yes/no
## 默认是 no表示关闭 ,yes表示开启。

持久化配置

  • always:每条 Redis 操作命令都会写入磁盘,最多丢失一条数据,但会使得Redis的性能降低,但数据几乎是全的,基本不会存在丢失数据问题。
  • everysec:每秒钟写入一次磁盘,最多丢失一秒的数据,对存取数据和性能折中,可以满足大部分使用场景。
  • no:不设置写入磁盘的规则,根据当前操作系统来决定何时写入磁盘,一般不采用这种设置。
  • 手动触发

使用bgrewriteaof命令可以手动触发aof持久化

随着时间的推移和数据量变大,aof一直在进行持久化,磁盘日志越来越大,redis重启速度越来越慢,针对这个问题,Redis提供了AOF重写功能。

Redis中的数据是有一定限量的,最多不超过物理内存大小,不可能说Redis中的数据无限增长,导致aof也无限增长,到一定的时候Redis就会采用缓存淘汰算法LRU自动将以部分数据从内存中给清除。

AOF 重写配置

  • auto-aof-rewrite-min-size:允许 AOF 重写的最小文件容量,默认是 64m 。
  • auto-aof-rewrite-percentage:AOF 文件重写的大小比例,默认值是 100,表示 100%,也就是只有当前 AOF 文件,比最后一次(上次)的 AOF 文件大一倍时,才会启动 AOF 文件重写。

AOF 重写流程

AOF 是存放每条写命令的,所以会不断变大,达到一定的时候,AOF做rewrite操作,会重新生成一个新的AOF文件。

优缺点

AOF 优点

AOF 持久化保存的数据更加完整,AOF 提供了三种保存策略:每次操作保存、每秒钟保存一次、跟随系统的持久化策略保存,其中每秒保存一次,从数据的安全性和性能两方面考虑是一个折中的选择,也是 AOF 默认的策略,即使发生了意外情况,最多只会丢失 1s 钟的数据;

AOF 采用的是命令追加的写入方式,所以不会出现文件损坏的问题,即使由于某些意外原因,导致了最后操作的持久化数据写入了一半,也可以通过 redis-check-aof 工具轻松的修复;

AOF 持久化文件,非常容易理解和解析,它是把所有 Redis 键值操作命令,以文件的方式存入了磁盘。即使不小心使用 flushall 命令删除了所有键值信息,只要使用 AOF 文件,删除最后的 flushall 命令,重启 Redis 即可恢复之前误删的数据。

AOF 缺点

对于相同的数据集来说,AOF 文件要大于 RDB 文件;

在 Redis 负载比较高的情况下,RDB 比 AOF 性能更好;

RDB 使用快照的形式来持久化整个 Redis 数据,而 AOF 只是将每次执行的命令追加到 AOF 文件中,因此从理论上说,RDB 比 AOF 更健壮。

混合持久化

RDB和AOF持久化各有优缺点,RDB会导致一段时间内的数据丢失,AOF文件会越来越大,会影响Redis的启动速度,为了同时兼顾RDB,AOF的优点,Redis在4.0版本之后提供了混合持久化方式。

混合持久化

AOF 重写时会把 Redis 的持久化数据,以 RDB 的格式写入到 AOF 文件的开头,之后的数据再以 AOF 的格式化追加的文件的末尾,如下图所示。

开启混合4.0之后可用

no改为yes即可

# rdb+aof两种机制结合使用
aof-use-rdb-preamble yes

混合持久化优缺点

优点

混合持久化结合了 RDB 和 AOF 持久化的优点,开头为 RDB 的格式,使得 Redis 可以更快的启动,同时结合 AOF 的优点,有减低了大量数据丢失的风险。

缺点:

AOF 文件中添加了 RDB 格式的内容,会使得 AOF 文件的可读性会很差,不容易阅读


http://www.kler.cn/a/390268.html

相关文章:

  • 恩山论坛任务python脚本
  • apache-skywalking-apm-10.1.0使用
  • 【WEB】网络传输中的信息安全 - 加密、签名、数字证书与HTTPS
  • 提供的 IP 地址 10.0.0.5 和子网掩码位 /26 来计算相关的网络信息
  • hive迁移后修复分区慢,怎么办?
  • C#补充----反射,特性,迭代器,特殊语法,值类型运用类型。
  • websocket服务器(协程风格)--swoole进阶篇
  • 【Spring Boot 入门四】Spring Boot安全机制 - 保护你的应用安全
  • Mi动漫 2.2.1 | 全新UI,永久免费无广告,免登录畅享动漫
  • 2024 高质量 Java 面试题集锦:高级 Java 工程师面试八股汇总
  • 宏远股份转战北交所:现金流连年为负,核心技术人员兼任董监高
  • 关于 3D Engine Design for Virtual Globes(三维数字地球引擎设计)
  • C++:搜索二叉树
  • 第十七章 TCP 客户端 服务器通信 - 使用OPEN命令
  • 使用 VueJS 构建 VS Code 扩展
  • 【QT常用技术讲解】任务栏图标+socket网络服务+开机自启动
  • mysql数据库(四)单表查询
  • 【idea】idea2024版本创建项目时没有java 8的版本选择
  • TOEIC 词汇专题:科技硬件篇
  • 【AI新领域应用】AlphaFold 2,原子级别精度的蛋白质3D结构预测,李沐论文精读(2021Nature封面,2024诺贝尔奖)
  • Python——飞机大战
  • 如何在 FastReport VCL 中创建报告时使用样式
  • Springboot 使用EasyExcel导出含图片并设置样式的Excel文件
  • 第四十二章 Vue中使用mutations修改Vuex仓库数据
  • 【JAVA】-Springboot核心机制
  • 智能量化模型在大数据下的中阳策略发展