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文件