Redis6 持久化之 RDB
825字约3分钟
2024-08-10
Redis 提供了 2 个不同形式的持久化方式
RDB(Redis DataBase)
AOF(Append Of File)
RDB 介绍
在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是 snapshot 快照,它恢复时是将快照文件直接读到内存里。
优势
适合大规模的数据恢复
对数据完整性性和一致性要求不高更合适使用
节省磁盘空间
恢复速度快
劣势
Fork 的时候,内存中的数据被克隆了一份,大致 2 倍的膨胀性需要考虑
虽然 Redis 在 Fork 时使用了写时拷贝技术,但是如果数据庞大时还是比较消耗性能
在备份周期一定间隔时间做一次备份,如果 Redis 意外 down 掉的话,就会丢失最后一次快照后的所有修改
备份
Redis 会单独创建(fork)一个子进程来进行持久化,会先将数据写入到一个临时文件中,待持久化过程都结束了,再用这个临时文件替换上次持久化好的文件。整个过程中,主进程不进行任何 IO 操作的,这就确保了极高的性能,如果需要进行大规模数据的恢复,且对于数据恢复的完整性不是非常敏感,那 RDB 方式要比 AOF 方式更加高效。RDB 的缺点是最后一次持久化后的数据可能丢失。
Fork
Fork 的作用是复制一个与当前进程一样的进程。新进程的所有数据(变量、环境变量、程序计数器等)数值都和原进程一致,但是是一个全新的进程,并作为原进程的子进程
在 Linux 程序中,fork() 会产生一个和父进程完全相同的子进程,但子进程在此后都会 exec 系统调用,处于效率考虑,Linux 中引入了“写时复制技术”
一般情况父进程和子进程会公用一段物理内存,只有进程空间的各段的内容要发生变化时,才会将父进程的内容复制一份给子进程
save bgsave
配置文件中有个 save ""
可以设置
save:save 时只管保存,其它不管,全部阻塞,手动保存,不建议。
bgsave:Redis 会在后台异步进行快照操作,快照同时还可以响应客户端请求。
可以通过 lastsave 命令获取最后一次成功执行快照的时间
stop-writes-on-bgsave-error
当 Redis 无法写入磁盘的话,直接关掉 Redis 的写操作,推荐 yes,stop-writes-on-bgsave-error yes
rdbcompression
rdbcompression yes
对于存储在磁盘中的快照,可以设置是否进行压缩存储。如果是的话,redis 会采用 LZF 算法进行压缩。如果不想消耗 CPU 资源来进行压缩的话,可以设置为关闭次功能,推荐 yes
rdbchecksum
rdbchecksum yes
检查完整性,在存储快照后,还可以让 redis 使用 CRC64 算法来进行数据校验
但是这样做会增加大约 10% 的性能消耗,如果希望获取到最大的性能提升,可以关闭此功能