AOF、RDB和复制功能对过期键的处理

本文将介绍RDB持久化功能、AOF持久化功能以及复制功能是如何处理数据库中的过期键。

RDB

生成RDB文件

在执行SAVE命令或者BGSVAE命令创建一个新的RDB文件时,程序会对数据库的键进行检查,过期的键不会被保存到RDB文件中。

载入RDB文件

在启动服务器的时候,若服务器开启了RDB功能,那么服务器将对RDB文件进行载入:

  • 如果服务器以主服务器模式启动,那么在载入RDB文件时,程序会对文件中保存的键进行检查,过期的键不会被载入到数据库中。
  • 如果服务器以从服务器模型启动,那么在载入RDB文件,无论键是否过期,都会被载入到数据库。不过,主从服务器在进行数据同步的时候,从服务器的数据库就会被清空。所以一般来说,过期键对于载入RDB文件的从服务器没有影响。

AOF

AOF文件写入

当服务器以AOF持久化模式运行,如果数据库中的某个键已经过期,但还没有被惰性删除或定期删除,这不会对AOF文件有任何影响。 当过期键被惰性删除或定期删除,程序会向AOF文件追加一条DEL命令,来显示地记录该键已被删除。

AOF重写

在执行AOF重写的过程中,程序会对数据库中的键进行检查,若键已经过期,则不会保存到重写后的AOF文件中。

复制

当服务器运行在复制模式下时,从服务器的过期键删除动作由主服务器控制。

  • 主服务器删除过期键的时候,会向所有从服务器发送DEL命令,告诉从服务器删除这个过期键。
  • 从服务器在执行客户端读命令时,即使碰到过期键也不会删除,而是像处理未过期键一样处理过期键。
  • 从服务器只有在接到主服务器发来的DEL命令,才删除过期键。

通过由主服务器来控制从服务器统一地删除过期键,可以保证主从服务器数据的一致性。

相关推荐
gQ85v10Db1 分钟前
Redis分布式锁进阶第三十二篇
数据库·redis·分布式
AI人工智能+电脑小能手5 分钟前
【大白话说Java面试题 第47题】【JVM篇】第7题:Young GC 和 Full GC 分别采用什么算法?
java·jvm·后端·算法·面试
xu_ws6 分钟前
redis的io多路复用和Java NIO的区别
java·redis·nio
Devin~Y16 分钟前
大厂Java面试实录:Spring Boot微服务 + Redis/Kafka + Prometheus/Jaeger + RAG/Agent(小Y水货版)
java·spring boot·redis·spring cloud·kafka·prometheus·jaeger
user_admin_god20 分钟前
Spring Boot 3 + WebFlux 企业级流式SSE接口最佳实践
java·spring boot·后端
怪祝浙20 分钟前
spring boot的启动原理以及mvc和ssm的解释
spring boot·后端·mvc
_Evan_Yao31 分钟前
责任链模式在Agent编排中的应用:让AI Agent学会“踢皮球”
java·人工智能·后端·责任链模式
lvrongbao41 分钟前
互联网大厂Java面试场景:从Spring到Redis的技术问答解析
java·redis·spring·微服务·分布式事务
counting money1 小时前
MavenServlet项目文件上传
java·后端
摇滚侠10 小时前
Redis 秒杀功能 超卖问题 一人一单问题 分布式锁 精彩!精彩!
redis·分布式·bootstrap