Redis持久化——AOF(Append Only File)

一、是什么?

  • 以日志的形式來(lái)記錄每個(gè)寫(xiě)操作,將Redis執(zhí)行過(guò)的所有寫(xiě)指令記錄下來(lái)(讀操作不記錄),只許追加文件但不可以改寫(xiě)文件,redis啟動(dòng)之初會(huì)讀取該文件重新構(gòu)建數(shù)據(jù),換言之,redis重啟的話(huà)就根據(jù)日志文件的內(nèi)容將寫(xiě)指令從前到后執(zhí)行一次以完成數(shù)據(jù)的恢復(fù)工作。

優(yōu)勢(shì)

  • 每次修改同步:appendfsync always 同步持久化 每次發(fā)生數(shù)據(jù)變更會(huì)被立即記錄到磁盤(pán) ,性能較差但數(shù)據(jù)完整性比較好。
  • 每秒同步:appendfsync everysec 異步操作,每秒記錄 如果一秒內(nèi)宕機(jī),有數(shù)據(jù)丟失。
  • 不同步:appendfsync no 從不同步。

劣勢(shì)

  • 相同數(shù)據(jù)集的數(shù)據(jù)而言AOF文件要遠(yuǎn)大于RDB文件,恢復(fù)速度慢于RDB。
  • AOF運(yùn)行效率要慢于RDB,每秒同步策略效率較好,不同步效率和RDB相同。

二、AOF介紹

  • 可以同時(shí)啟用AOF和RDB持久化,不會(huì)出現(xiàn)任何問(wèn)題。
  • 在啟動(dòng)Redis服務(wù)時(shí), 如果啟用了AOF,則Redis將加載AOF文件進(jìn)行數(shù)據(jù)恢復(fù),這是是具有更好持久性保證的文件。

三、AOF啟動(dòng)配置

# 開(kāi)啟AOF持久化,默認(rèn):no,開(kāi)啟改為 yes
appendonly no
# AOF文件的名字,建議使用默認(rèn)值。
appendfilename "appendonly.aof"

# Redis支持三種不同的備份模式:
# always:同步持久化 每次發(fā)生數(shù)據(jù)變更會(huì)被立即記錄到磁盤(pán)  性能較差但數(shù)據(jù)完整性比較好
# everysec:出廠默認(rèn)推薦,異步操作,每秒記錄   如果一秒內(nèi)宕機(jī),有數(shù)據(jù)丟失
# no:不要fsync,只要讓操作系統(tǒng)在需要的時(shí)候刷新數(shù)據(jù)即可。得更快。
# appendfsync always
appendfsync everysec
# appendfsync no

# 重寫(xiě)時(shí)是否可以運(yùn)用Appendfsync,用默認(rèn)no即可,保證數(shù)據(jù)安全性。
no-appendfsync-on-rewrite no

# 設(shè)置重寫(xiě)的基準(zhǔn)值
# 指定百分比為0,以禁用自動(dòng)AOF重寫(xiě)特性。
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb

四、AOF恢復(fù) (RDB同理)

正?;謴?fù)

  • 將有數(shù)據(jù)的AOF文件復(fù)制一份保存到對(duì)應(yīng)目錄(config get dir)
  • 恢復(fù):重啟redis然后重新加載

異?;謴?fù)

  • 備份被寫(xiě)壞的AOF文件
  • 修復(fù):執(zhí)行 redis-check-aof --fix appendonly.aof 進(jìn)行修復(fù)。
  • 重啟redis然后重新加載

AOF重寫(xiě)

是什么?

  • AOF采用文件追加的方式,文件會(huì)越來(lái)越大。為避免出現(xiàn)此種情況,新增了重寫(xiě)機(jī)制,當(dāng)AOF文件的大小超過(guò)所設(shè)定的閾值時(shí),Redis就會(huì)啟動(dòng)AOF文件的內(nèi)容壓縮,只保留可以恢復(fù)數(shù)據(jù)的最小指令集,可以使用命令bgrewriteaof。

重寫(xiě)原理:

  • AOF文件因持續(xù)增長(zhǎng)而過(guò)大時(shí),會(huì)fork出一條新進(jìn)程來(lái)將文件重寫(xiě)(也是先寫(xiě)臨時(shí)文件最后再rename),遍歷新進(jìn)程的內(nèi)存中數(shù)據(jù),每條記錄有一條的set語(yǔ)句。重寫(xiě)AOF文件的操作,并沒(méi)有讀取舊的AOF文件,而是將整個(gè)內(nèi)存中的數(shù)據(jù)庫(kù)內(nèi)容用命令的方式重寫(xiě)了一個(gè)新的aof文件,這點(diǎn)和快照有點(diǎn)類(lèi)似。

觸發(fā)機(jī)制:

  • Redis會(huì)記錄上次重寫(xiě)時(shí)的AOF大小。
  • 默認(rèn)配置是:當(dāng)AOF文件大小是上次rewrite后大小的一倍且文件大于64M時(shí)觸發(fā)。

五、總結(jié)

AOF.png
  • AOF文件是一個(gè)只進(jìn)行追加的日志文件。
  • Redis 可以在AOF文件體積變得過(guò)大時(shí)。自動(dòng)地在后臺(tái)對(duì)AOF進(jìn)行重寫(xiě)。
  • AOF文件有序的保存了對(duì)數(shù)據(jù)庫(kù)執(zhí)行的所有寫(xiě)入操作,這些寫(xiě)入操作以Redis協(xié)議的格式保存,因此AOF文件的內(nèi)容非常容易被人讀懂,對(duì)文件進(jìn)行分析也很輕松。
  • 對(duì)于相同的數(shù)據(jù)集來(lái)說(shuō),AOF文件的體積通常大于RBD文件的體積。
  • 根據(jù)所使用的的fsync策略,AOF的速度可能慢于RDB。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容