Redis—AOF持久化

AOF是Redis的一种持久化方式,通过记录写操作日志确保数据安全。它在执行命令后写入日志,减少检查开销,但可能造成数据丢失。Redis提供Always、Everysec和No三种写入硬盘策略。AOF文件过大时,会进行重写以压缩文件。AOF优点在于数据丢失量小且写入性能高,但恢复速度较慢,适合实时性要求高的场景。
摘要由CSDN通过智能技术生成

一、AOF定义

保存写操作命令到日志的持久化方式,就是 Redis 里的 AOF(Append Only File) 持久化功能

定义:以日志的形式记录每个操作,记录写指令不记录读指令,只许追加⽂件不允许修改,AOF保存的是appendonly.aof⽂件,恢复的时候从前到后执行⼀次。

二、AOF过程

Redis 是先执行写操作命令后,才将该命令记录到 AOF 日志里的

这样的好处有两点

1.避免额外的检查开销。

2.不会阻塞当前写操作命令的执行

AOF有两个风险

1.执行写操作命令和记录日志是两个过程,那当 Redis 在还没来得及将命令写入到硬盘时,服务器发生宕机了,这个数据就会有丢失的风险。

2.第二个风险,前面说道,由于写操作命令执行成功后才记录到 AOF 日志,所以不会阻塞当前写操作命令的执行,但是可能会给「下一个」命令带来阻塞风险

三、Redis三种写入硬盘的策略

Redis写入硬盘的过程

1. Redis 执行完写操作命令后,会将命令追加到 server.aof_buf 缓冲区;
2. 然后通过 write() 系统调用,将 aof_buf 缓冲区的数据写入到 AOF 文件,此时数据并没有写入到硬盘,而是拷贝到了内核缓冲区 page cache,等待内核将数据写入硬盘;
3. 具体内核缓冲区的数据什么时候写入到硬盘,由内核决定。

三种写入硬盘的策略

1. Always,每次写操作命令执行完后,同步将 AOF 日志数据写回硬盘;
2. Everysec,每次写操作命令执行完后,先将命令写入到 AOF 文件的内核缓冲区,然后每隔一秒将缓冲区里的内容写回到硬盘;
3. No,意味着不由 Redis 控制写回硬盘的时机,转交给操作系统控制写回的时机,也就是每次写操作命令执行完后,先将命令写入到 AOF 文件的内核缓冲区,再由操作系统决定何时将缓冲区内容写回硬盘。

四、AOF重写机制

当 AOF 文件的大小超过所设定的阈值后,Redis 就会启用 AOF 重写机制,来压缩 AOF 文件。

AOF 重写机制是在重写时,读取当前数据库中的所有键值对,然后将每一个键值对用一条命令记录到「新的 AOF 文件」,等到全部记录完后,就将新的 AOF 文件替换掉现有的 AOF 文件。

五、AOF优缺点

▪ 优点:

• 如果后台线程每秒执行fsync,数据最多丢失⼀秒

• 直接追加在⽂件末尾,写入性能⾼

▪ 缺点:

• aof文件大,恢复速度慢;

• 数据恢复慢,不适合做冷备

RedisAOF持久化是指将Redis的每次写操作记录下来,以日志的形式保存到磁盘上,从而保证数据的持久性和完整性。具体来说,Redis AOF持久化有两种配置参数:appendfsync always和appendfsync no。 当appendfsync参数设置为always时,每次写入都会立刻记录到AOF日志中,保证了数据的完整性,但会对性能产生一定影响。 而当appendfsync参数设置为no时,Redis不会主动进行同步,而是将同步时机交给操作系统,由操作系统来决定何时将数据写入磁盘。这种方式相对于always来说,性能更好,但数据的完整性可能会受到一定影响。 总的来说,AOF持久化机制更稳健,丢失数据的概率较低,并且可以通过AOF日志文件来处理误操作。然而,相比于RDB持久化方式,AOF占用更多的磁盘空间,恢复备份的速度也较慢。此外,如果每次读写都进行同步,可能会对性能造成一定的压力。同时也需要注意,AOF持久化机制存在个别Bug,可能导致无法正确恢复数据。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Redis持久化AOF(详解)](https://blog.csdn.net/weixin_45737330/article/details/127248907)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱吃代码的航航

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值