美文网首页
redis的持久化

redis的持久化

作者: 阿长_一个程序员 | 来源:发表于2019-10-17 17:18 被阅读0次

redis有2种持久化方法

1.RDB

手动触发为bgsave命令


bgsave命令的运作流程

1)执行bgsave命令,Redis父进程判断当前是否存在正在执行的子进程,如RDB/AOF子进程,如果存在bgsave命令直接返回。

2)父进程执行fork操作创建子进程,fork操作过程中父进程会阻塞。

3)父进程fork完成后,可以继续响应其他命令。

4)子进程创建RDB文件,根据父进程内存生成临时快照文件,完成后对原有文件进行原子替换。

5)进程发送信号给父进程表示完成

RDB的优点/缺点
  • 优点
    Redis加载RDB恢复数据远远快于AOF的方式

  • 缺点
    RDB方式数据没办法做到实时持久化/秒级持久化。因为bgsave每次运行都要执行fork操作创建子进程,属于重量级操作,频繁执行成本过高。

2.AOF

以独立日志的方式记录每次写命令,重启时再重新执行AOF文件中的命令达到恢复数据的目的。
AOF的主要作用是解决了数据持久化的实时性。


AOF工作流程

1)所有的写入命令会追加到aof_buf(缓冲区)中。
AOF为什么把命令追加到aof_buf中?Redis使用单线程响应命令,如果每次写AOF文件命令都直接追加到硬盘,那么性能完全取决于当前硬盘负载。

2)AOF缓冲区根据对应的策略向硬盘做同步操作

同步文件策略

  • always
    每次写入都要同步AOF文件,在一般的SATA硬盘上,Redis只能支持大约几百TPS写入,显然跟Redis高性能特性背道而驰,不建议配置。

  • everysec
    是建议的同步策略,也是默认配置,做到兼顾性能和数据安全性。理论上只有在系统突然宕机的情况下丢失1秒的数据。

  • no
    由于操作系统每次同步AOF文件的周期不可控,而且会加大每次同步硬盘的数据量,虽然提升了性能,但数据安全性无法保证。

3)AOF文件重写
随着命令不断写入AOF,文件会越来越大,为了解决这个问题,Redis引入AOF重写机制压缩文件体积。

4)重启加载
AOF和RDB文件都可以用于服务器重启时的数据恢复。下图表示Redis持久化文件加载流程

Redis持久化文件加载流程

相关文章

网友评论

      本文标题:redis的持久化

      本文链接:https://www.haomeiwen.com/subject/mwhvmctx.html