Redis持久化簡(jiǎn)述

RDB持久化

RDB文件的生成和載入

生成RDB文件的命令:SAVE和BGSAVE

SAVE命令阻塞Redis進(jìn)程,BGSAVE使用子線程來(lái)進(jìn)行持久化

RDB文件的載入是服務(wù)器在啟動(dòng)過(guò)程中檢測(cè)到RDB,自動(dòng)載入的篓吁,此處有個(gè)前提:AOF持久化功能處于關(guān)閉狀態(tài)孵构,否則優(yōu)先使用AOF文件來(lái)還原數(shù)據(jù)

自動(dòng)間歇性保存

//服務(wù)器在900秒之內(nèi),對(duì)數(shù)據(jù)庫(kù)至少進(jìn)行了一次修改
save 900 1
//服務(wù)器在300秒之內(nèi),對(duì)數(shù)據(jù)庫(kù)至少進(jìn)行了10次修改
save 300 10 
//服務(wù)器在60秒之內(nèi),對(duì)數(shù)據(jù)庫(kù)進(jìn)行了至少10000次修改
save 60 10000

AOF持久化

AOF持久化是通過(guò)保存Redis服務(wù)器所執(zhí)行的寫命令來(lái)記錄數(shù)據(jù)庫(kù)的狀態(tài)的。

持久化過(guò)程:
命令追加-->文件寫入-->文件同步

  • 命令追加剿配,服務(wù)器執(zhí)行一個(gè)寫命令之后,會(huì)以協(xié)議格式追加到aof_buf緩沖區(qū)的末尾阅束;
  • 文件寫入呼胚,將命令寫入aof文件,但是未將文件刷入磁盤息裸;
  • 文件同步蝇更,即刷盤

Redis通過(guò)appendfasync參數(shù)來(lái)控制持久化行為:

  • always,將aof_buf緩沖區(qū)中所有內(nèi)容寫入并同步到AOF文件呼盆,該方式下Redis性能最差年扩,但是安全性最高,數(shù)據(jù)丟失控制在一個(gè)文件事件之內(nèi)访圃;
  • everysec厨幻,將aof_buf緩沖區(qū)所有內(nèi)容寫入aof文件,每一秒進(jìn)行一次aof文件同步腿时,該方式Redis在性能和安全性方面做了折中選擇况脆;
  • no,將aof——buf緩沖區(qū)所有內(nèi)容寫入aof文件批糟,同步的時(shí)間交給操作系統(tǒng)自己決定格了,該方式Redis性能最好,但是異常宕機(jī)可能丟失大量數(shù)據(jù)徽鼎。

AOF文件記錄服務(wù)器的寫命令盛末,隨著服務(wù)器在線時(shí)間的推移,AOF文件中內(nèi)容會(huì)越來(lái)越多否淤,甚至可能撐爆磁盤悄但,所以我們需要進(jìn)行AOF重寫,新的AOF文件和舊的AOF文件保存著相同的Redis狀態(tài)石抡,但是不存在數(shù)據(jù)冗余檐嚣,并且新AOF文件的生成不涉及到對(duì)舊AOF文件的讀寫。

Redis是如何進(jìn)行無(wú)阻塞的AOF文件重寫汁雷?
當(dāng)后臺(tái)調(diào)用BGREWRITEAOF指令時(shí)净嘀,Redis會(huì)進(jìn)行無(wú)阻塞的進(jìn)行AOF文件的重寫,Redis會(huì)開(kāi)啟一個(gè)子進(jìn)程侠讯,使用子進(jìn)程可以使父進(jìn)程挖藏,即服務(wù)器進(jìn)程能夠繼續(xù)對(duì)外提供服務(wù),同時(shí)避免使用鎖的情況下厢漩,保證數(shù)據(jù)的安全性膜眠。但是存在一個(gè)問(wèn)題,在AOF重寫期間溜嗜,服務(wù)器進(jìn)程繼續(xù)處理命令請(qǐng)求宵膨,新的命令可能對(duì)數(shù)據(jù)庫(kù)的狀態(tài)進(jìn)行了修改,使得服務(wù)器當(dāng)前狀態(tài)和重寫后的服務(wù)器狀態(tài)不一致炸宵,為了解決這個(gè)問(wèn)題辟躏,Redis設(shè)置了一個(gè)AOF重寫緩沖區(qū),當(dāng)Redis執(zhí)行寫命令時(shí)土全,會(huì)同時(shí)將命令追加到AOF緩沖區(qū)和AOF重寫緩沖區(qū)捎琐,那么子進(jìn)程在執(zhí)行AOF重寫期間服務(wù)器需要執(zhí)行三個(gè)工作:

  • 執(zhí)行客戶端發(fā)送的命令;
  • 將執(zhí)行的寫命令追加到AOF緩沖區(qū)裹匙;
  • 將執(zhí)行的命令追加到AOF重寫緩沖區(qū)瑞凑;

當(dāng)子進(jìn)程完成重寫之后,會(huì)向父進(jìn)程發(fā)送一個(gè)信號(hào)概页,父進(jìn)程調(diào)用信號(hào)處理函數(shù)籽御,執(zhí)行以下操作:

  • 將AOF重寫緩沖區(qū)中的所有內(nèi)容寫入到新的AOF文件中,這是新的AOF文件狀態(tài)與當(dāng)前服務(wù)器狀態(tài)一致惰匙;
  • 對(duì)新的AOF文件進(jìn)行改名技掏,原子性的覆蓋現(xiàn)有的AOF文件,完成新舊AOF文件的替換项鬼。

注:信號(hào)處理函數(shù)處理過(guò)程中需要阻塞Redis零截。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市秃臣,隨后出現(xiàn)的幾起案子涧衙,更是在濱河造成了極大的恐慌,老刑警劉巖奥此,帶你破解...
    沈念sama閱讀 218,525評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件弧哎,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡稚虎,警方通過(guò)查閱死者的電腦和手機(jī)撤嫩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)蠢终,“玉大人序攘,你說(shuō)我怎么就攤上這事茴她。” “怎么了程奠?”我有些...
    開(kāi)封第一講書人閱讀 164,862評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵丈牢,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我瞄沙,道長(zhǎng)己沛,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,728評(píng)論 1 294
  • 正文 為了忘掉前任距境,我火速辦了婚禮申尼,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘垫桂。我一直安慰自己师幕,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,743評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布诬滩。 她就那樣靜靜地躺著们衙,像睡著了一般。 火紅的嫁衣襯著肌膚如雪碱呼。 梳的紋絲不亂的頭發(fā)上蒙挑,一...
    開(kāi)封第一講書人閱讀 51,590評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音愚臀,去河邊找鬼忆蚀。 笑死,一個(gè)胖子當(dāng)著我的面吹牛姑裂,可吹牛的內(nèi)容都是我干的馋袜。 我是一名探鬼主播,決...
    沈念sama閱讀 40,330評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼舶斧,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼欣鳖!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起茴厉,我...
    開(kāi)封第一講書人閱讀 39,244評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤泽台,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后矾缓,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體怀酷,經(jīng)...
    沈念sama閱讀 45,693評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,885評(píng)論 3 336
  • 正文 我和宋清朗相戀三年嗜闻,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蜕依。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,001評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖样眠,靈堂內(nèi)的尸體忽然破棺而出友瘤,到底是詐尸還是另有隱情,我是刑警寧澤檐束,帶...
    沈念sama閱讀 35,723評(píng)論 5 346
  • 正文 年R本政府宣布辫秧,位于F島的核電站,受9級(jí)特大地震影響厢塘,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜肌幽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,343評(píng)論 3 330
  • 文/蒙蒙 一晚碾、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧喂急,春花似錦格嘁、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,919評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至狡孔,卻和暖如春懂诗,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背苗膝。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,042評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工殃恒, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人辱揭。 一個(gè)月前我還...
    沈念sama閱讀 48,191評(píng)論 3 370
  • 正文 我出身青樓离唐,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親问窃。 傳聞我的和親對(duì)象是個(gè)殘疾皇子亥鬓,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,955評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容