国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Redis > 正文

內存型數據庫Redis持久化小結

2020-03-17 12:36:20
字體:
來源:轉載
供稿:網友

因為Redis是內存型數據庫,所以為了防止因為系統崩潰等原因導致數據丟失的問題,Redis提供了兩種不同的持久化方法來將數據存儲在硬盤里面,一種方法是快照(RDB),它可以將存在于某一個時刻的所有數據都寫入到硬盤里面,另外一種方法是只追加文件(AOF),它會在執行寫命令時,將被執行的寫命令都寫入到硬盤里面。

快照持久化

Redis可以通過創建快照來獲得在內存里面的數據在某一個時間點上的副本。在創建快照之后,用戶可以對快照進行備份,可以將快照復制到其它服務器從而創建具有相同數據的服務器副本,還可以將快照留在原地以便重啟服務器時使用。

有兩個命令可以用于生成RDB文件,一個是SAVE,另外一個BGSAVE。

在只使用快照持久化來保存數據時,如果系統真的發生崩潰,用戶將丟失最近一次生成快照之后更改的所有數據。因此,快照持久化只適用于那些即使丟失一部分數據也不會造成問題的應用程序。

SAVE

特點:SAVE命令會阻塞Redis服務器進程,直到RDB文件創建完畢,在服務器進程阻塞期間,服務器不能處理任何命令請求。

缺點:服務器持久化期間無法接受其它請求。

BGSAVE

特點:BGSAVE命令則會派生出一個子進程,然后由子進程負責創建RDB文件,服務器進程則繼續處理命令請求。

缺點:創建子進程所耗費的時間會隨著Redis占用的內存而增加。

AOF持久化

AOF持久化會將被執行的寫命令寫到AOF文件的末尾,以此來紀錄數據所發生的變化,因此,Redis只要從頭到尾重新執行一次AOF文件所包含的所有寫命令,就可以恢復AOF文件所記錄的數據集。

在設置同步頻率的時候,存在三個選項:

 

選項 同步頻率
always 每個Redis寫命令都要同步寫入硬盤,但是這樣做會占用Redis所擁有的內存,嚴重降低Redis的速度
everysec 每秒執行一次同步,顯式地將多個寫命令同步到硬盤
no 讓操作系統來決定應該何時進行同步

 

最好使用everysec,既能避免每次都寫入所造成的性能影響,又能避免操作系統崩潰所導致的可能丟失不定量數據,其即使系統崩潰,用戶最多只會丟失一秒之內產生的數據,當硬盤忙于執行寫入操作的時候,Redis還會優雅的放慢自己的速度以便適應硬盤的最大寫入速度。

缺點:因為Redis會不斷的將被執行的寫命令紀錄到AOF文件里面,所以隨著Redis不斷執行,AOF文件的體積也會不斷增長,極端條件下,AOF甚至可能會用完硬盤的所有可用空間。

為了解決上面的缺點,Redis提供了BGREWRITEAOF命令,這個命令會通過移除AOF文件中的冗余命令來重寫AOF文件,使得AOF文件盡可能的小。它的原理和BGSAVE命令相似,Redis會創建一個子進程,然后由子進程負責對AOF文件進行重寫,因為AOF文件重寫也需要用到子進程,所以同樣存在快照持久化因為創建子進程所導致的性能問題和內存占用問題。


注:相關教程知識閱讀請移步到Redis頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 营口市| 千阳县| 涟源市| 奉新县| 山阳县| 大田县| 建始县| 平阳县| 正定县| 阳山县| 周宁县| 金阳县| 桦甸市| 青州市| 清河县| 东至县| 新安县| 会宁县| 白城市| 项城市| 宁武县| 昭苏县| 奎屯市| 洪雅县| 攀枝花市| 新巴尔虎左旗| 峨山| 双流县| 兰考县| 平顶山市| 宣威市| 桑日县| 阳谷县| 务川| 麻城市| 云林县| 南部县| 铅山县| 灌南县| 安西县| 武城县|