內(nèi)存型數(shù)據(jù)庫(kù)Redis持久化小結(jié)
因?yàn)镽edis是內(nèi)存型數(shù)據(jù)庫(kù),所以為了防止因?yàn)橄到y(tǒng)崩潰等原因?qū)е聰?shù)據(jù)丟失的問(wèn)題,Redis提供了兩種不同的持久化方法來(lái)將數(shù)據(jù)存儲(chǔ)在硬盤(pán)里面,一種方法是快照(RDB),它可以將存在于某一個(gè)時(shí)刻的所有數(shù)據(jù)都寫(xiě)入到硬盤(pán)里面,另外一種方法是只追加文件(AOF),它會(huì)在執(zhí)行寫(xiě)命令時(shí),將被執(zhí)行的寫(xiě)命令都寫(xiě)入到硬盤(pán)里面。
快照持久化
Redis可以通過(guò)創(chuàng)建快照來(lái)獲得在內(nèi)存里面的數(shù)據(jù)在某一個(gè)時(shí)間點(diǎn)上的副本。在創(chuàng)建快照之后,用戶可以對(duì)快照進(jìn)行備份,可以將快照復(fù)制到其它服務(wù)器從而創(chuàng)建具有相同數(shù)據(jù)的服務(wù)器副本,還可以將快照留在原地以便重啟服務(wù)器時(shí)使用。
有兩個(gè)命令可以用于生成RDB文件,一個(gè)是SAVE,另外一個(gè)BGSAVE。
在只使用快照持久化來(lái)保存數(shù)據(jù)時(shí),如果系統(tǒng)真的發(fā)生崩潰,用戶將丟失最近一次生成快照之后更改的所有數(shù)據(jù)。因此,快照持久化只適用于那些即使丟失一部分?jǐn)?shù)據(jù)也不會(huì)造成問(wèn)題的應(yīng)用程序。
SAVE
特點(diǎn):SAVE命令會(huì)阻塞Redis服務(wù)器進(jìn)程,直到RDB文件創(chuàng)建完畢,在服務(wù)器進(jìn)程阻塞期間,服務(wù)器不能處理任何命令請(qǐng)求。
缺點(diǎn):服務(wù)器持久化期間無(wú)法接受其它請(qǐng)求。
BGSAVE
特點(diǎn):BGSAVE命令則會(huì)派生出一個(gè)子進(jìn)程,然后由子進(jìn)程負(fù)責(zé)創(chuàng)建RDB文件,服務(wù)器進(jìn)程則繼續(xù)處理命令請(qǐng)求。
缺點(diǎn):創(chuàng)建子進(jìn)程所耗費(fèi)的時(shí)間會(huì)隨著Redis占用的內(nèi)存而增加。
AOF持久化
AOF持久化會(huì)將被執(zhí)行的寫(xiě)命令寫(xiě)到AOF文件的末尾,以此來(lái)紀(jì)錄數(shù)據(jù)所發(fā)生的變化,因此,Redis只要從頭到尾重新執(zhí)行一次AOF文件所包含的所有寫(xiě)命令,就可以恢復(fù)AOF文件所記錄的數(shù)據(jù)集。
在設(shè)置同步頻率的時(shí)候,存在三個(gè)選項(xiàng):
| 選項(xiàng) | 同步頻率 |
|---|---|
| always | 每個(gè)Redis寫(xiě)命令都要同步寫(xiě)入硬盤(pán),但是這樣做會(huì)占用Redis所擁有的內(nèi)存,嚴(yán)重降低Redis的速度 |
| everysec | 每秒執(zhí)行一次同步,顯式地將多個(gè)寫(xiě)命令同步到硬盤(pán) |
| no | 讓操作系統(tǒng)來(lái)決定應(yīng)該何時(shí)進(jìn)行同步 |
最好使用everysec,既能避免每次都寫(xiě)入所造成的性能影響,又能避免操作系統(tǒng)崩潰所導(dǎo)致的可能丟失不定量數(shù)據(jù),其即使系統(tǒng)崩潰,用戶最多只會(huì)丟失一秒之內(nèi)產(chǎn)生的數(shù)據(jù),當(dāng)硬盤(pán)忙于執(zhí)行寫(xiě)入操作的時(shí)候,Redis還會(huì)優(yōu)雅的放慢自己的速度以便適應(yīng)硬盤(pán)的最大寫(xiě)入速度。
缺點(diǎn):因?yàn)镽edis會(huì)不斷的將被執(zhí)行的寫(xiě)命令紀(jì)錄到AOF文件里面,所以隨著Redis不斷執(zhí)行,AOF文件的體積也會(huì)不斷增長(zhǎng),極端條件下,AOF甚至可能會(huì)用完硬盤(pán)的所有可用空間。
為了解決上面的缺點(diǎn),Redis提供了BGREWRITEAOF命令,這個(gè)命令會(huì)通過(guò)移除AOF文件中的冗余命令來(lái)重寫(xiě)AOF文件,使得AOF文件盡可能的小。它的原理和BGSAVE命令相似,Redis會(huì)創(chuàng)建一個(gè)子進(jìn)程,然后由子進(jìn)程負(fù)責(zé)對(duì)AOF文件進(jìn)行重寫(xiě),因?yàn)锳OF文件重寫(xiě)也需要用到子進(jìn)程,所以同樣存在快照持久化因?yàn)閯?chuàng)建子進(jìn)程所導(dǎo)致的性能問(wèn)題和內(nèi)存占用問(wèn)題。
相關(guān)文章
Redis數(shù)據(jù)庫(kù)安裝部署及基本操作詳解
這篇文章主要介紹了Redis數(shù)據(jù)庫(kù)安裝部署及基本操作,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08
Web-ssrfme:redis 未授權(quán)訪問(wèn)攻擊的問(wèn)題解決
本文主要介紹了Web-ssrfme:redis 未授權(quán)訪問(wèn)攻擊的問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2025-04-04
redis實(shí)現(xiàn)簡(jiǎn)單分布式鎖
這篇文章主要介紹了redis實(shí)現(xiàn)簡(jiǎn)單分布式鎖,文中通過(guò)代碼示例講解的非常詳細(xì),需要的朋友可以參考下2013-09-09
Redis特殊數(shù)據(jù)類(lèi)型Geospatial地理空間
這篇文章主要為大家介紹了Redis特殊數(shù)據(jù)類(lèi)型Geospatial地理空間,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
redis簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了redis簡(jiǎn)介,Redis是一個(gè)開(kāi)源的,先進(jìn)的 key-value 存儲(chǔ)可用于構(gòu)建高性能,可擴(kuò)展的 Web 應(yīng)用程序的解決方案,有興趣的可以了解一下2017-08-08
redis 數(shù)據(jù)刪除策略和逐出算法的問(wèn)題小結(jié)
這篇文章主要介紹了redis 數(shù)據(jù)刪除策略和逐出算法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
手把手教你使用redis實(shí)現(xiàn)排行榜功能
使用Redis中有序集合的特性來(lái)實(shí)現(xiàn)排行榜是又好又快的選擇,一般排行榜都是有實(shí)效性的,比如“用戶積分榜”,下面這篇文章主要給大家介紹了關(guān)于使用redis實(shí)現(xiàn)排行榜功能的相關(guān)資料,需要的朋友可以參考下2023-04-04

