RDB持久化

Redis的RDB持久化通过save和bgsave命令实现数据快照保存,其中bgsave通过子进程避免阻塞主线程。自动触发机制包括满足特定修改条件、全量复制时、debugreload和shutdown时。bgsave在多种场景下确保数据安全性。
摘要由CSDN通过智能技术生成

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.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值