什么是AOF持久化?
AOF持久化,即通过一个append only file来记录对数据库的写操作命令,从而只要重新执行这些命令就可以还原数据库。
AOF持久化可以保证数据的完整性
AOF持久化的步骤?
1:命令追加步骤
首先服务器将对数据库的写操作命令放入AOF缓冲区中,并通过周期函数来检查是否需要将缓冲区内的内容写入AOF文件中(一般有三种策略:always,everysecond,no)。这三种策略是在安全性与效率之间的平衡。
2:数据还原
通过创建一个不带网络连接的伪客户端,并依次执行AOF中的命令,从而实现数据的还原。
3:AOF重写
因为AOF是记录写操作命令,会导致文件的冗余,只要通过对数据库当前状态的重新读出,从而可以实现AOF的精简。
具体流程如下:
首先创建一个子进程(为什么不用线程呢?因为线程会造成锁,导致效率低下。而且用子进程不会阻塞父进程)
然后父进程创建一个AOF重写缓冲区,用于记录在AOF重写期间执行的写入命令。
一个写命令会同时发送给AOF缓冲区和AOF重写缓冲区。
然后等到重写完成,子进程向父进程发送信号,父进程会将AOF重写缓冲区的内容追加的新的AOF文件中,并原子化的替换原先的AOF文件。