-
定时触发: RDB 持久化是通过设置一个定时触发的机制来进行的。管理员可以配置 Redis 在经过一定时间间隔或执行了一定数量的写操作后触发 RDB 持久化。这个配置通常在 Redis 的配置文件中进行,可以通过
save
或save 900 1
这样的配置项来设定。bashsave 900 1 # 在900秒内如果有至少1个key被改变,则触发RDB持久化
-
创建数据快照: 当触发条件满足时,Redis 开始创建一个数据快照。这个数据快照是当前内存中所有数据的一个拷贝。
-
创建临时文件: Redis 在创建数据快照的同时,会创建一个临时文件用于存储这个数据快照。这样可以确保在持久化过程中不会影响到当前正在运行的 Redis 服务器。
-
写入数据: 将数据快照写入到临时文件中,确保数据的完整性。这个过程通常是先将数据写入到一个临时文件中,然后再用原子操作将临时文件替换掉旧的 RDB 文件。
-
替换旧文件: 一旦新的 RDB 文件创建完成,Redis 就会用这个新文件替换掉原来的 RDB 文件。这个过程通常是原子的,这意味着在替换的瞬间,Redis 要么完全替换,要么完全不替换。
-
完成持久化: 当替换完成后,Redis 完成了一次 RDB 持久化。这个过程是非常快速的,因为 Redis 只需将内存中的数据写入硬盘。
Redis 使用 RDB 持久化方式的过程
严定洲2024-02-17 10:29
相关推荐
阿华的代码王国几秒前
【JavaEE】——文件IO的应用satan–06 分钟前
R语言的下载、安装及环境配置(Rstudio&VSCode)电饭叔38 分钟前
《python语言程序设计》2018版第8章19题几何Rectangle2D类(下)-头疼的几何和数学Eternal-Student39 分钟前
everyday_question dq20240731极客先躯43 分钟前
高级java每日一道面试题-2024年10月3日-分布式篇-分布式系统中的容错策略都有哪些?卑微求AC1 小时前
(C语言贪吃蛇)11.贪吃蛇方向移动和刷新界面一起实现面临的问题夜月行者1 小时前
如何使用ssm实现基于SSM的宠物服务平台的设计与实现+vue程序猿小D1 小时前
第二百六十七节 JPA教程 - JPA查询AND条件示例Yvemil71 小时前
RabbitMQ 入门到精通指南潘多编程1 小时前
Java中的状态机实现:使用Spring State Machine管理复杂状态流转