【Redis】持久化机制RDB与AOF

一、RDB

RDB模式是就是将内存中的数据存储到磁盘中,等到连接断开的时候会进行持久化操作。但是如果服务器宕机,会导致这个持久化机制不会执行,但是内存中的文件会直接丢失。所以可以设置一个触发机制,save 60 1000 就是代表60秒 执行1000次修改就触发这个条件,等这个数据数量到达了一定值的时候,就出发持久化操作。这个持久化文件是存储在当前运行的目录中。

进行持久化的过程是这样的,主进程会开启一个子进程将数据持久化到磁盘中,这个过程中他们其实操作数据都不是操作的真是的磁盘中的数据,而是对虚拟数据进行操作,是一个页表,它映射着真实磁盘空间的数据,开启子进程后它会把这个页表发送给子进程,然后让子进程将这个页表中的数据持久化到磁盘中。

缺点:fork开启一个子进程,复制页表,压缩RDB文件过程中消耗时间。

二、AOF

它是一种追加命令的持久化机制,它是将操作过程中的命令都存储在一个文件里面,如果等断开连接的时候,可能会有数据丢失,那么我执行这个AOF持久化文件就能恢复数据。这个不是默认开启的,需要手动开启。

并且持久化的评率也可以手动开启

对比RDB 和AOF 模式,RDB需要压缩文件,FORK子进程,复制页表,存储数据,存的速度慢,AOF存的速度快直接存储指令。RDB的读取速度快,直接数据导入,AOF模式慢因为要把所有指令执行一次。RDB会压缩文件存储文件比较小,AOF存储文件较大。RDB丢失数据概率更大一些,AOF会小一些,因为他有及时存储数据到自己的持久化文件,而RDB需要配置触发条件,或者连接断开才会触发。

相关推荐
鸠摩智首席音效师14 分钟前
MySQL ERROR 1114 (HY000): The table is full
数据库·mysql
数据大魔方19 分钟前
【期货量化实战】豆粕期货量化交易策略(Python完整代码)
开发语言·数据库·python·算法·github·程序员创富
橘子的代码日记38 分钟前
[redis]黑马点评-商品类型缓存(课后练习)
缓存
Codeking__39 分钟前
Redis的value类型介绍——zset
数据库·redis·缓存
muddjsv41 分钟前
SQLite3 核心命令全解析 (从入门到精通)
数据库
難釋懷44 分钟前
认识NoSQL
数据库·nosql
xiaolyuh12344 分钟前
Redis 核心业务流程
java·redis·spring
亿坊电商1 小时前
利于SEO优化的CMS系统都有哪些特点?
前端·数据库
阿阿阿安1 小时前
MySQL(一)数据库风险操作场景总结
数据库·mysql
心丑姑娘1 小时前
使用ClickHouse时的劣质SQL样例
数据库·sql·clickhouse