AOF 日志是怎样实现的?
1、aof介绍
Redis作为内存数据库,数据都存储在内存中,如果遇见宕机情况,没有持久化机制,数据肯定是会丢失的,为了实现数据库在宕机之后可以恢复,redis提供了aof(append only file)和rdb(内存快照)两种日志记录方式。aof 通过将指令写入文件方式实现持久化,不同于普通数据库的“写前日志”(WAL),aof 采用的是“写后日志”,即先执行指令,然后再把执行成功的指令写入文件,这样就可避免写入文件前的指令校验过程(已经执行成功的指令必然是不需要再校验的)。
所以采用写后日志有两个优点:
- 写入的日志不会存在错误日志。
- 由于写日志是写入之后再进行,所以不会阻塞当前的写操作。
但同时也带来两个问题:
- 写后日志必然存在异常宕机后的数据丢失问题(如果指令执行成功,但还未写入日志,此时宕机,便导致数据丢失)。
- 写后虽然避免了阻塞当前的写操作,但可能会阻塞下一指令的写操作,因为写aof日志的操作依然是在主进程中进行的,如果写入磁盘压力过高就会阻塞住后续指令写入。
2、aof日志格式
不同于传统数据库的redo log(重做日志),即日志保存修改后的数据内容,aof采用的是直接以文件形式存储每次写入的指令,如下图所示,以“se