概述
RDB持久化是把当前进程数据生成快照保存到硬盘的过程,触发RDB持久化过程分为手动触发和自动触发。
触发机制:
手动触发分别对应save和bgsave命令:
1.save命令:阻塞当前redis服务器,知道RDB过程完成为止,对于内存比较大的实例会造成长时间阻塞,线上和环境不建议使用。
2.bgsave命令:redis进程执行fork操作创建子进程,RDB持久化过程由子进程负责,完成后自动结束。阻塞只发生在fork阶段,一般时间很短。 bgsave命令是针对save租的问题做的优化。因此redis内部所有的设计RDB的操作都采用bgsave的方式,而save命令已经废弃。
自动触发机制:
如下场景会使用自动触发机制:
1)使用save相关配置,如“save m n ” 表示m秒内数据集存在n次修改时,自动触发bgsave
2)如果从节点执行全量复制操作,主节点自动执行bgsave生成RDB文件并发送给从节点。
3)执行debug reload 命令重新加载redis时,也会自动触发save操作
4)默认情况下执行shutdown命令时,如果没有开启AOF持久化功能则自动执行bgsave.
最后
以上就是忧伤楼房为你收集整理的RDB持久化的全部内容,希望文章能够帮你解决RDB持久化所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复