-
概念
-
持久化就是把内存的数据写到磁盘中,防止服务宕机导致内存数据丢失
-
Redis提供了两种不同的持久化方法可以将数据存储在磁盘中,一种叫快照RDB,另一种叫只追加文件AOF
-
-
RDB
-
RDB持久化是把当前时刻的数据生成快照写入磁盘
-
由fork子进程写入到临时rdb文件,然后等快照数据写入完成替换旧的rdb文件,用二进制压缩存储
-
-
优点
-
RDB可以更快地恢复数据,因为直接将快照文件加载到内存
-
使用单独子进程来进行持久化,主进程不会进行任何 IO 操作,保证了Redis的高性能
-
-
缺点
-
RDB无法保证数据的绝对安全,可能会丢失最后一次快照之后的数据
-
-
-
AOF
-
概念
-
将Redis执行过的所有写指令记录下来(读操作不记录),追加到AOF日志,Redis会在收到客户端修改指令后,先将该指令文本追加到AOF日志中,也就是先存到磁盘,然后再执行指令,这样即使遇到突发宕机,已经存储到AOF日志的指令进行重放一下就可以恢复到宕机前的状态
-
-
优点
-
AOF相比于RDB可以更好的保护数据不丢失
-
可以配置 AOF 每秒执行一次追加日志操作,如果Redis进程挂掉,最多丢失1秒的数据
-
-
-
缺点
-
将所有的写指令追加到AOF日志中导致AOF日志文件较大,占用的空间比rdb文件更大
-
AOF的数据恢复速度比RDB慢,因为要重新执行日志中的操作
-
-
Redis如何做的持久化的?
最新推荐文章于 2024-07-07 17:47:43 发布