0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Redis持久化AOF原理學習

麥辣雞腿堡 ? 來源:七哥聊編程 ? 作者:七哥聊編程 ? 2023-10-09 15:02 ? 次閱讀
原理

在學習AOF原理前,我們首先要了解 RESP (Redis的序列化協(xié)議)

圖片

從圖中可以看到客戶端在調用redis服務端時,傳入的命令和 key、value 都會通過 RESP 協(xié)議序列化為文本。AOF文件中存儲的就是序列化后的reids命令。

AOF同步和RDB類似之處在于都是采用fork進程來處理:

圖片

通過這張圖,我們知道了Redis是將客戶端傳入的命令直接寫入AOF文件的,那如果同一個key原本值是0,然后改為1,最后在改為2,如果每一條命令都記錄不僅毫無意義,同時會使得AOF文件越來越大,所以 Redis 在這塊有一個小優(yōu)化。

AOF重寫(優(yōu)化AOF文件)
set s1 11
set s1 22

上面的操作,如果沒有優(yōu)化之前AOF文件是會將這兩個命令按照RESP序列化后存儲,如果優(yōu)化后,則只存儲后面一條命令即 set s1 22,同一個key的值被覆蓋了,只存儲最終結果。

重寫過程分析

那如果做到同一個key在AOF文件中只存儲最新的值呢?不可能每一次寫入文件前去檢查一遍刪除之前這個key的值吧,這樣做效率肯定賊低,我們來看看Redis是怎么做的?

Redis 其實是會定期新創(chuàng)建一個 AOF 文件,然后做 AOF 文件的重寫優(yōu)化,在創(chuàng)建新 AOF 文件的過程中,會繼續(xù)將命令追加到現(xiàn)有的 AOF 文件里面,即使重寫過程中發(fā)生停機,現(xiàn)有的 AOF 文件也不會丟失。而一旦新 AOF 文件創(chuàng)建完畢, Redis 就會從舊 AOF 文件切換到新 AOF 文件,并開始對新 AOF 文件進行追加操作。

這個操作不得不說還是玩的66的!大寫的服。

優(yōu)化的觸發(fā)條件:

那上面說的定期重建 AOF 文件具體的時機是啥時候呢?答案也在配置文件 redis.conf 中,需要如下的配置即可,我已經(jīng)寫了注釋,你一眼就能看懂的。

# 表示當前aof文件大小超過上一次aof文件大小的百分之多少的時候會進行重寫。如果之前沒有重寫過,以啟動時aof文件大小為準
auto-aof-rewrite-percentage 100
# 限制允許重寫最小aof文件大小,也就是文件大小小于64mb的時候,不需要進行優(yōu)化
auto-aof-rewrite-min-size 64mb
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 內存
    +關注

    關注

    8

    文章

    2966

    瀏覽量

    73814
  • 數(shù)據(jù)庫

    關注

    7

    文章

    3752

    瀏覽量

    64233
  • Redis
    +關注

    關注

    0

    文章

    370

    瀏覽量

    10830
收藏 人收藏

    評論

    相關推薦

    Redis堅持持久方式概述

    Redis 持久
    發(fā)表于 09-25 17:04

    阿里云基于NVM的持久高性能Redis數(shù)據(jù)庫

    各自業(yè)務需求,在讀寫性能、緩存容量、數(shù)據(jù)可靠性等方面作出靈活的選擇。Redis提供了RDB和AOF兩種持久方式供選擇,4.0中更是引入了RDB-A
    發(fā)表于 08-13 15:06 ?271次閱讀

    Redis持久機制的實現(xiàn)原理和使用技巧

    Redis將數(shù)據(jù)存儲在內存中,宕機或重啟都會使內存數(shù)據(jù)全部丟失, Redis持久機制用來保證數(shù)據(jù)不會因為故障而丟失。
    的頭像 發(fā)表于 09-13 16:42 ?973次閱讀

    Redis持久化分為兩種:RDB和AOF

    Redis持久,一個老掉牙的問題,但是面試官就是喜歡問。這也是我們學Redis必會的一個知識點。
    的頭像 發(fā)表于 02-21 09:22 ?647次閱讀

    Redis是什么?簡述它的優(yōu)缺點?

    /s,寫的速度是81000次/s。 支持數(shù)據(jù)持久,支持AOF和RDB兩種持久方式。 支持事務, Re
    的頭像 發(fā)表于 10-09 10:37 ?770次閱讀

    Redis持久機制介紹

    Redis持久機制? 為了能夠重用Redis數(shù)據(jù),或者防止系統(tǒng)故障,我們需要將Redis中的數(shù)據(jù)寫入到磁盤空間中,即
    的頭像 發(fā)表于 10-09 11:44 ?458次閱讀
    <b class='flag-5'>Redis</b><b class='flag-5'>持久</b><b class='flag-5'>化</b>機制介紹

    Redis持久RDB方式介紹

    Redis持久 Redis是一個內存數(shù)據(jù)庫,為了保證數(shù)據(jù)的持久性,它提供了兩種持久
    的頭像 發(fā)表于 10-09 14:56 ?477次閱讀
    <b class='flag-5'>Redis</b><b class='flag-5'>持久</b><b class='flag-5'>化</b>RDB方式介紹

    redis持久方式有幾種及配置

    Redis是一種內存數(shù)據(jù)庫,為了避免數(shù)據(jù)丟失,需要將數(shù)據(jù)持久到磁盤上。Redis提供了兩種持久
    的頭像 發(fā)表于 12-04 11:09 ?591次閱讀

    redis兩種持久方式的區(qū)別

    的完整性和一致性。 Redis提供了兩種持久方式:RDB(Redis Database)和AOF(Append Only File)。這兩
    的頭像 發(fā)表于 12-04 11:12 ?484次閱讀

    redis持久方式RDB和AOF的區(qū)別

    Redis 是一個高性能的鍵值對數(shù)據(jù)庫,提供了兩種持久方式:RDB 和 AOF。RDB 是將 Redis 的數(shù)據(jù)快照保存到磁盤上,而
    的頭像 發(fā)表于 12-04 16:25 ?728次閱讀

    redis持久機制和如何實現(xiàn)持久

    Redis是一款高性能的非關系型數(shù)據(jù)庫,其持久機制是保證數(shù)據(jù)在重啟后仍能夠保存的關鍵。Redis提供了兩種方式來實現(xiàn)持久
    的頭像 發(fā)表于 12-05 10:02 ?430次閱讀

    redis持久機制優(yōu)缺點

    持久機制:RDB(Redis Database)和AOF(Append Only File)。 RDB持久
    的頭像 發(fā)表于 12-05 10:03 ?654次閱讀

    redis里數(shù)據(jù)什么時候持久

    Redis是一種開源的高性能、非關系型內存數(shù)據(jù)庫,它使用了鍵值對存儲數(shù)據(jù),并且支持多種數(shù)據(jù)結構。 Redis提供了持久機制,以確保在服務器重啟后數(shù)據(jù)不會丟失。
    的頭像 發(fā)表于 12-05 10:05 ?408次閱讀

    云容器redis持久配置

    丟失。 Redis提供了不同的持久機制,可以根據(jù)需要進行配置。本文將詳細介紹云容器中Redis持久
    的頭像 發(fā)表于 12-05 10:07 ?473次閱讀

    redis持久rdb和aof一起用好處

    Redis是一個流行的內存數(shù)據(jù)庫,它通過使用不同的持久機制來確保數(shù)據(jù)的持久性。RDB和AOFRedi
    的頭像 發(fā)表于 12-05 10:17 ?708次閱讀