持久化

1.RDB(Redis DataBase):保存某個時間點的全量數(shù)據(jù)快照

以快照的形式將進(jìn)程數(shù)據(jù)持久化到硬盤,RDB創(chuàng)建一個經(jīng)過壓縮的二進(jìn)制文件,以“.rdb”結(jié)尾,內(nèi)部存儲了各個數(shù)據(jù)庫的鍵值對數(shù)據(jù)等信息。(相當(dāng)于備份數(shù)據(jù)庫狀態(tài))

觸發(fā)方式:

image.png

子進(jìn)程記錄接受BGSAVE當(dāng)時的數(shù)據(jù)庫狀態(tài),父進(jìn)程繼續(xù)處理接受到的命令,子進(jìn)程完成文件創(chuàng)建之后發(fā)送信號給父進(jìn)程,父進(jìn)程處理命令的同時,通過輪詢來接受子進(jìn)程的信號

image.png
  1. 檢查是否存在RDB/AOF的子進(jìn)程存在,若存在,則直接返回

  2. 若不存在,則觸發(fā)持久化,調(diào)用rdbSaveBackground方法執(zhí)行fork()系統(tǒng)調(diào)用創(chuàng)建子進(jìn)程,fork后,父進(jìn)程響應(yīng)其他命令,子進(jìn)程創(chuàng)建.rdb文件,并存儲父進(jìn)程內(nèi)存中的數(shù)據(jù)。

  3. 父進(jìn)程得到通知,以新文件替換舊的.rdb文件

image.png

2.AOF(Append Only File)

以獨立日志的方式,記錄了每次寫入命令,重啟時再重新執(zhí)行AOF文件中的命令來恢復(fù)數(shù)據(jù)(備份接受到的指令)

image.png
image.png

3.RDB和AOF優(yōu)缺點

image.png

5.RDB-AOF混合持久化方式

先以RDB格式寫入全量數(shù)據(jù),再追加增量數(shù)據(jù)

image.png

Redis實例重啟時,使用BGSAVE持久化文件重新構(gòu)建內(nèi)容,再使用AOF重放近期的操作指令,實現(xiàn)完整恢復(fù)重啟之前的狀態(tài)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

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

  • Redis支持RDB和AOF兩種持久化機(jī)制,持久化功能有效地避免因進(jìn)程退出造成的數(shù)據(jù)丟失問題,當(dāng)下次重啟時利用之前...
    程序猿小董閱讀 351評論 0 0
  • 前言 在上一篇文章中,介紹了Redis內(nèi)存模型,從這篇文章開始,將依次介紹Redis高可用相關(guān)的知識——持久化、復(fù)...
    Java架構(gòu)閱讀 2,503評論 3 21
  • 一、Redis高可用概述 在介紹Redis高可用之前,先說明一下在Redis的語境中高可用的含義。 我們知道,在w...
    胸毛飄逸閱讀 316評論 0 2
  • 一、Redis高可用概述 在介紹Redis高可用之前,先說明一下在Redis的語境中高可用的含義。 我們知道,在w...
    Java架構(gòu)_師閱讀 476評論 0 2
  • 企業(yè)級redis集群架構(gòu)的特點 海量數(shù)據(jù) 高并發(fā) 高可用 要達(dá)到高可用,持久化是不可減少的,持久化主要是做災(zāi)難恢復(fù)...
    lucode閱讀 2,280評論 0 7

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