极客时间《Redis核心技术与实战》开篇词 知识点总结

news/2024/11/26 9:22:17/

Redis 主要的数据持久化方式

RDB(Redis Database Backup file)

RDB 是 Redis 提供的一种数据快照持久化方式,它会在指定的时间间隔内生成数据集的时间点快照,并将这些快照保存到磁盘上的一个 RDB 文件中。RDB 文件是一个压缩的二进制文件,它包含了 Redis 在某个时间点上的数据。

RDB 的特点

  1. 数据完整性:RDB 文件包含了 Redis 数据库中的所有数据,可以用来进行数据备份和灾难恢复
  2. 性能影响小:RDB 持久化是在后台进行的,使用子进程来完成数据的写入操作,对主进程的性能影响较小。
  3. 恢复速度快:RDB 文件是二进制文件,启动时加载速度较快。
  4. 数据可能丢失:如果 Redis 服务在两次快照之间发生故障,那么这段时间内的数据变更将会丢失。

AOF(Append Only File)

AOF 是 Redis 提供的另一种持久化方式,它通过记录每次写操作命令来记录数据库状态。AOF 文件是一个只追加的日志文件,每次对 Redis 数据库的写操作都会被追加到 AOF 文件中。

AOF 的特点

  1. 数据安全性高:AOF 可以配置为每次写操作后都同步到磁盘,这样可以保证数据的安全性,但可能会影响性能。
  2. 数据恢复:AOF 文件可以用于数据恢复,因为它记录了所有的写操作命令。
  3. 文件体积大:由于 AOF 记录了所有写操作命令,文件可能会变得非常大。
  4. 数据恢复速度慢:由于 AOF 文件包含了所有的写操作命令,数据恢复时需要逐条命令执行,这可能会比 RDB 恢复慢。
  5. 可配置的同步频率:AOF 可以配置为每秒、每次写操作或不同步,以平衡数据安全性和性能。

选择 RDB 还是 AOF

选择 RDB 还是 AOF 取决于具体的应用场景和需求:

  • 如果数据的完整性和一致性非常重要,且可以容忍短时间内的数据丢失,可以选择 RDB。
  • 如果需要更细粒度的数据恢复,或者数据安全性要求较高,可以选择 AOF。
  • 在实际应用中,也可以同时开启 RDB 和 AOF,这样可以结合两者的优点,既保证了数据的安全性,也提高了数据恢复的速度。

Redis 4.0 以后,还引入了混合持久化功能,它结合了 RDB 和 AOF 的优点,先记录 RDB 快照,然后记录 AOF 增量命令,这样可以在保证数据安全性的同时,提高数据恢复的速度。

存在的问题

在高并发场景里,会直接带来两个新问题:一个是写 AOF 和 RDB 会造成 Redis 性能抖动,另一个是 Redis 集群数据同步和实例恢复时,读 RDB 比较慢,限制了同步和恢复速度。


http://www.ppmy.cn/news/1550020.html

相关文章

Docker 配置 HTTP 和 HTTPS 网络代理

前言 在内网环境中,为了实现全局代理上网,Linux 系统通常通过修改 .bashrc 或 /etc/profile 等文件,设置 HTTP 和 HTTPS 代理。这种方式可以为大多数应用提供代理支持,但 Docker 并不会自动读取系统的环境变量,因此需…

谷粒商城-消息队列Rabbitmq

RabbitMq参考文档 在谷粒商城项目中使用消息队列主要有以下几个重要原因: 异步处理提高性能 场景示例:在订单系统中,当用户提交订单后,系统需要完成多个操作,如更新库存、生成订单记录、发送订单通知等。如果这些操作…

动态规划 详解

动态规划(Dynamic Programming, DP)详解 动态规划是一种通过分解问题为子问题并利用子问题的解来解决原问题的算法设计方法。它通常用于解决具有 重叠子问题 和 最优子结构 性质的问题。 1. 动态规划的核心思想 1.1 重叠子问题 问题可以分解为多个子问…

【C语言】野指针问题详解及防范方法

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C语言 文章目录 💯前言💯什么是野指针?💯未初始化的指针代码示例问题分析解决方法 💯指针越界访问代码示例问题分析解决方法 💯指向已释放内存的…

navicat密码解密python

其他资料都是用php写的,但是运行起来好像有点问题,提供python代码,首先注册表获取加密后的密码,然后运行下述代码解密。 参考:获取navicat密码 import hashlib from Crypto.Cipher import AES, Blowfish from Crypto.…

内存不足引发C++程序闪退崩溃问题的分析与总结

目录 1、内存不足一般出现在32位程序中 2、内存不足时会导致malloc或new申请内存失败 2.1、malloc申请内存失败,返回NULL 2.2、new申请内存失败,抛出异常 3、内存不足项目实战案例中相关细节与要点说明 3.1、内存不足导致malloc申请内存失败&#…

【Pytest+Yaml+Allure】实现接口自动化测试框架

一、框架思想 requestsyamlpytestallure实现接口自动化框架。结合数据驱动和分层思想,将代码与数据分离,易维护,易上手。使用yaml编写编写测试用例,利用requests库发送请求,使用pytest管理用例,allure生成…

Linux常用指令(1)

目录 何为指令 基本常用指令 1.clear 2.exit 3.whoami 4.pwd 5.which 6.alias 7.tree ls指令 pwd指令 cd指令 touch指令 mkdir指令 rmdir指令 && rm指令 rmdir指令 rm指令 man指令 cp指令 何为指令 指令的本质其实就是可执行程序。 指令 可执行文件…