深入理解Redis—AOF实现

Redis的AOF持久化通过记录写命令来保存数据库状态,启动时执行AOF文件中的命令还原数据库。AOF持久化包括命令追加、文件写入与同步。服务器在每个事件循环结束前可能将AOF缓冲区内容写入文件,根据appendfsync配置。AOF文件载入时,通过伪客户端执行写命令还原数据。AOF重写创建新文件以减少冗余,使用子进程执行以避免阻塞服务器,并通过AOF重写缓冲区保证数据一致性。
摘要由CSDN通过智能技术生成

AOF

  • AOF持久化是通过Redis服务器所执行的写命令来记录数据库状态的;
  • 服务器在启动时,通过载入和执行AOF文件中的保存的命令来还原服务器关闭之前的数据库状态;
  • AOF持久化功能的实现分为“命令追加”、“文件写入”、“文件同步”三个步骤;
    1. 命令追加:当AOF持久化功能处于开启状态时,服务器在执行一个写命令之后,会以协议格式 将 被执行的写命令追加到服务器状态的aof_buf缓冲区的末尾(AOF缓冲区);
    2. 文件的写入与同步:服务器在处理文件事件时可能会执行写命令,将一些内容追加到缓冲区中,Redis服务器会在每次结束一个事件循环之前,调用flushAppendOnlyFile函数,考虑是否将缓冲区当中的内容写入和保存到AOF文件里面;(flushAppendOnlyFile函数的执行计划根据服务器配置的appendfsync选项参数的值来决定,默认为everysec)
  • AOF文件的载入与数据还原:AOF文件里面包含了重建数据库状态所需的所有写命令,服务器只需要读入并执行一遍AOF文件中保存的写命令,即可还原服务器关闭之前的数据库状态;
    1. 具体步骤:1. 创建一个
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值