redis的持久化

2019-10-17  本文已影响0人  阿长_一个程序员

redis有2种持久化方法

1.RDB

手动触发为bgsave命令


bgsave命令的运作流程

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

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

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

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

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

RDB的优点/缺点

2.AOF

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


AOF工作流程

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

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

同步文件策略

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

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

Redis持久化文件加载流程
上一篇下一篇

猜你喜欢

热点阅读