极客时间 Redis核心技术与实战 笔记(基础篇 AOF和RDB)

本文介绍了Redis的AOF日志和内存快照(RDB)机制。AOF日志是写后日志,确保正确命令被执行并记录,避免阻塞操作。三种写回策略包括同步、每秒同步和不同步。当AOF文件过大时,采用重写机制减小文件大小。RDB提供全量快照,通过bgsave子进程避免阻塞。文章讨论了快照频率与磁盘压力、内存开销的权衡,并提出混合使用AOF和RDB以兼顾恢复速度和数据丢失风险。
摘要由CSDN通过智能技术生成

AOF日志

AOF 日志是如何实现的?

数据库的写前日志(Write Ahead Log, WAL):在实际写数据前,先把修改的数据记到日志文件中,以便故障时进行恢复。
AOF 日志正好相反,是写后日志:“写后”的意思是 Redis 是先执行命令,把数据写入内存,然后才记录日志,如下图所示:
在这里插入图片描述
传统数据库的日志,例如 redo log(重做日志),记录的是修改后的数据,而 AOF 里记录的是 Redis 收到的每一条命令,这些命令是以文本形式保存的。

写后日志两大好处

  • 可以避免出现记录错误命令的情况

为了避免额外的检查开销,Redis 在向 AOF 里面记录日志的时候,并不会先去对这些命令进行语法检查。所以,如果先记日志再执行命令的话,日志中就有可能记录了错误的命令,Redis 在使用日志恢复数据时,就可能会出错。
而写后日志这种方式,就是先让系统执行命令,只有命令能执行成功,才会被记录到日志中,否则,系统就会直接向客户端报错。

  • 不会阻塞当前的写操作

两个潜在的风险

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值