Redis持久化机制RDB和AOF

Redis支持两种持久化机制,RDB和AOF

一、RDB(Redis Data Base)快照模式

(1)原理:将Redis的所有key和value以快照的形式写入文件;

(2)实现:

        save:主线程手动save命令写入快照,

        缺点:进行数据写入持久化,会阻塞主线程,生产不允许,会在一定时间内阻塞主线程

        bgsave:创建子线程,专门用来写入RDB文件,

        缺点:快照需要时间,当子进行正在进行持久化时,如果有新的写入命令,可能会导致数据丢失,redis在进行子线程创建的时候也会阻塞主线程;

二、AOF(append only file):先执行命令,把命令append到一个AOF的缓冲区,再调研write函数去将写命令 追加到文件
    1、先写命令,再进行文件追加
    2、不是立马写,而是根据配置策略写,每秒写一次,或者一直写
    3、不是直接写文件,再追加文件,是先写到缓冲区
    4、对同一个key多次操作进行重写的时候,中间的命令也要重写,只取最后一条

优点:哪怕redis发生故障导致没完成写也可以修复(最多也就丢失1秒钟的数据),write函数因为是创建新文件,执行完命令后再追加到旧文件,即使写新文件出错,也不会影响旧文件

三、Redis新版本使用混合持久化,在Redis重启的时候有优势,RBD文件保存到AOF文件里面;

四、两种方式持久化触发后都会生成一个dump.rbd文件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值