亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

redis持久化AOF和RDB的區(qū)別及解決各個場景問題示例

 更新時間:2023年08月24日 10:39:56   作者:jacheut  
這篇文章主要為大家介紹了redis持久化AOF和RDB的區(qū)別及解決各個場景問題示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

什么是Redis持久化?

redis是一種內存數(shù)據(jù)庫。持久化就是把內存的數(shù)據(jù)寫到磁盤中去,防止服務宕機了內存數(shù)據(jù)丟失。

Redis提供了兩種持久化策略: RDB(默認) 和AOF 。

RDB是指在指定的時間間隔內,把內存中的數(shù)據(jù)集快照寫入磁盤。也就是只保留某個時間點的數(shù)據(jù)。
而AOF持久化會記錄服務器接收的所有寫操作命令,并且把這些命令追加到一個文件里面,持久化到磁盤上,在服務器啟動的時候,通過重新執(zhí)行這些命令來還原數(shù)據(jù)。

RDB快照

rdb是Redis DataBase縮寫。

功能核心函數(shù)rdbSave(生成RDB文件)和rdbLoad(從文件加載內存)兩個函數(shù)。

RBD持久化通過保存數(shù)據(jù)庫中的鍵值對來記錄數(shù)據(jù)庫狀態(tài)。

RBD配置文件的開啟

save 900 1      // 900s內,有1條寫入,則產(chǎn)生快照
save 300 1000   // 如果300秒內有1000次寫入,則產(chǎn)生快照
save 60 10000  // 如果60秒內有10000次寫入,則產(chǎn)生快照
(這3個選項都屏蔽,則rdb禁用)
stop-writes-on-bgsave-error yes  // 后臺備份進程出錯時,主進程是否停止寫入
rdbcompression yes    // 導出的rdb文件是否壓縮。建議沒有必要開啟,畢竟Redis本身就屬于CPU密集型服務器,再開啟壓縮會帶來更多的CPU消耗,相比硬盤成本,CPU更值錢。
rdbchecksum   yes //  導入rbd恢復數(shù)據(jù)時,是否驗證rdb的完整性
dbfilename dump.rdb  //導出來的rdb文件名
dir ./  //rdb的放置路徑

RDB原理

針對RDB方式的持久化,手動觸發(fā)可以使用:

save:會阻塞當前Redis服務器,直到持久化完成,線上應該禁止使用。

bgsave:該觸發(fā)方式會fork一個子進程,由子進程負責持久化過程,因此阻塞只會發(fā)生在fork子進程的時候。

而自動觸發(fā)的場景主要是有以下幾點:

  • 根據(jù)我們的 save m n 配置規(guī)則自動觸發(fā);
  • 從節(jié)點全量復制時,主節(jié)點發(fā)送rdb文件給從節(jié)點完成復制操作,主節(jié)點會觸發(fā) bgsave;
  • 執(zhí)行 debug reload 時;
  • 執(zhí)行 shutdown時,如果沒有開啟aof,也會觸發(fā)。

由于 save 基本不會被使用到,我們重點看看 bgsave 這個命令是如何完成RDB的持久化的。

這里注意的是 fork 操作會阻塞,導致Redis讀寫性能下降。我們可以控制單個Redis實例的最大內存,來盡可能降低Redis在fork時的事件消耗。以及上面提到的自動觸發(fā)的頻率減少fork次數(shù),或者使用手動觸發(fā),根據(jù)自己的機制來完成持久化。

BGSAVE命令執(zhí)行時的服務器狀態(tài)

首先,在BGSAVE命令執(zhí)行期間,客戶端發(fā)送的SAVE命令會被服務器拒絕,服務器禁止SAVE命令和BGSAVE命令同時執(zhí)行是為了避免父進程(服務器進程)和子進程同時執(zhí)行兩個rdbSave調用,防止產(chǎn)生競爭條件。

其次,在BGSAVE命令執(zhí)行期間,客戶端發(fā)送的BGSAVE命令會被服務器拒絕,因為同時執(zhí)行兩個BGSAVE命令也會產(chǎn)生競爭條件。

最后, BGREWRITEAOF和BGSAVE兩個命令不能同時執(zhí)行:

  • 如果BGSAVE命令正在執(zhí)行,那么客戶端發(fā)送的BGREWRITEAOF命令會被延遲到BGSAVE命令執(zhí)行完畢之后執(zhí)行。
  • 如果BGREWRITEAOF命令正在執(zhí)行,那么客戶端發(fā)送的BGSAVE命令會被服務器拒絕。

因為BGREWRITEAOF和BGSAVE兩個命令的實際工作都由子進程執(zhí)行,所以這兩個命令在操作方面并沒有什么沖突的地方,不能同時執(zhí)行它們只是一個性能方面的考慮-并
發(fā)出兩個子進程,并且這兩個子進程都同時執(zhí)行大量的磁盤寫入操作,這怎么想都不會是一個好主意。

AOF

Aof是Append-only file縮寫。

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

AOF持久化的實現(xiàn):

AOF持久化可分為命令追加、文件寫入、文件同步三個步驟。

從持久化中恢復數(shù)據(jù)

RDB文件的載入工作是在服務器啟動時自動執(zhí)行的,所以Redis并沒有專門用于載入RDB文件的命令,只要Redis服務器在啟動時檢測到RDB文件存在,它就會自動載入RDB文件。

服務器在載入RDB文件期間,會一直處于阻塞狀態(tài) ,直到載入完成。

另外值得一提的是,因為AOF文件的更新頻率通常比RDB文件的更新頻率高, 保存的數(shù)據(jù)更完整,AOF基本上最多損失1s的數(shù)據(jù)。所以:

  • 如果服務器開啟了AOF持久化功能,那么服務器會優(yōu)先使用AOF文件來還原數(shù)據(jù)陣狀態(tài)。
  • 只有在AOF持久化功能處于關閉狀態(tài)時,服務器才會使用RDB文件來還原數(shù)據(jù)庫狀態(tài)。

每當執(zhí)行服務器(定時)任務或者函數(shù)時flushAppendOnlyFile 函數(shù)都會被調用, 這個函數(shù)執(zhí)行以下兩個工作
aof寫入保存:

WRITE:根據(jù)條件,將 aof\_buf 中的緩存寫入到 AOF 文件

SAVE:根據(jù)條件,調用 fsync 或 fdatasync 函數(shù),將 AOF 文件保存到磁盤中。

那么這里為什么要先寫入buf在同步到磁盤呢?如果實時寫入磁盤會帶來非常高的磁盤IO,影響整體性能。

aof重寫是為了減少aof文件的大小,可以手動或者自動觸發(fā)

手動觸發(fā): bgrewriteaof,自動觸發(fā) 就是根據(jù)配置規(guī)則來觸發(fā),當然自動觸發(fā)的整體時間還跟Redis的定時任務頻率有關系。

下面來看看重寫的一個流程圖:

對于上圖有四個關鍵點補充一下:

  • 在重寫期間,由于主進程依然在響應命令,為了保證最終備份的完整性;因此它依然會寫入舊的AOF file中,如果重寫失敗,能夠保證數(shù)據(jù)不丟失。
  • 為了把重寫期間響應的寫入信息也寫入到新的文件中,因此也會為子進程保留一個buf,防止新寫的file丟失數(shù)據(jù)。
  • 重寫是直接把當前內存的數(shù)據(jù)生成對應命令,并不需要讀取老的AOF文件進行分析、命令合并。
  • AOF文件直接采用的文本協(xié)議,主要是兼容性好、追加方便、可讀性高可認為修改修復。
  • 不管是RDB還是AOF都是先寫入一個臨時文件,然后通過 rename 完成文件的替換工作。

Aof 的配置

appendonly no # 是否打開 aof日志功能
# 文件名稱
appendfilename "appendonly.aof"
appendfsync always   # 每1個命令,都立即同步到aof. 安全,速度慢
#appendfsync everysec # 折衷方案,每秒寫1次
#appendfsync no      # 寫入工作交給操作系統(tǒng),由操作系統(tǒng)判斷緩沖區(qū)大小,統(tǒng)一寫入到aof. 同步頻率低,速度快,
no-appendfsync-on-rewrite  yes: # 正在導出rdb快照的過程中,是否停止同步aof
auto-aof-rewrite-percentage 100 #aof文件大小比起上次重寫時的大小,增長率100%時,重寫
auto-aof-rewrite-min-size 64mb #aof文件,至少超過64M時,才重寫

AOF和RDB比較

  • aof文件比rdb更新頻率高,優(yōu)先使用aof還原數(shù)據(jù)。—— 更加穩(wěn)定,數(shù)據(jù)的完整性更好。
  • aof比rdb更安全也更大。—— 記錄了每一個寫操作,但是隨著文件越來越大,可能會影響到redis的寫性能。
  • rdb性能比aof好:恢復大數(shù)據(jù)集的速度比AOF快,對CPU和內存的影響比較小。更加適用于需要做冷備份或者對數(shù)據(jù)恢復要求不高的場景,因為它是間隔一段時間進行持久化。如果在這個時間斷內發(fā)生宕機,那么這些數(shù)據(jù)就會丟失。
  • 如果兩個都配了優(yōu)先加載AOF。
  • AOF適用于對數(shù)據(jù)安全性較高的場景,比如購物車/訂單等關鍵性業(yè)務。

定時任務執(zhí)行的頻率可以在配置文件中通過 hz 10 來設置(這個配置表示1s內執(zhí)行10次,也就是每100ms觸發(fā)一次定時任務)。該值最大能夠設置為:500,但是不建議超過:100,因為值越大說明執(zhí)行頻率越頻繁越高,這會帶來CPU的更多消耗,從而影響主進程讀寫性能。
定時任務使用的是Redis自己實現(xiàn)的 TimeEvent,它會定時去調用一些命令完成定時任務,這些任務可能會阻塞主進程導致Redis性能下降。因此我們在配置Redis時,一定要整體考慮一些會觸發(fā)定時任務的配置,根據(jù)實際情況進行調整。

以上就是redis持久化AOF和RDB的區(qū)別及解決各個場景問題示例的詳細內容,更多關于redis持久化AOF RDB的資料請關注腳本之家其它相關文章!

相關文章

  • 一文帶你了解Redis的三種集群模式

    一文帶你了解Redis的三種集群模式

    Redis?的常用的集群方式主要有以下三種,分別是主從復制模式、哨兵模式、Redis-Cluster集群模式,那么下面我們就分別了解一下這三種集群模式的優(yōu)點與缺點
    2023-06-06
  • Redis中LFU算法的深入分析

    Redis中LFU算法的深入分析

    這篇文章主要給大家介紹了關于Redis中LFU算法的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Redis具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-06-06
  • Redis緩存空間優(yōu)化實踐詳解

    Redis緩存空間優(yōu)化實踐詳解

    緩存Redis,是我們最常用的服務,其適用場景廣泛,被大量應用到各業(yè)務場景中。也正因如此,緩存成為了重要的硬件成本來源,我們有必要從空間上做一些優(yōu)化,降低成本的同時也會提高性能,本文通過代碼示例介紹了redis如何優(yōu)化緩存空間,需要的朋友可以參考一下
    2023-04-04
  • Redis+Caffeine多級緩存數(shù)據(jù)一致性解決方案

    Redis+Caffeine多級緩存數(shù)據(jù)一致性解決方案

    兩級緩存Redis+Caffeine可以解決緩存雪等問題也可以提高接口的性能,但是可能會出現(xiàn)緩存一致性問題,如果數(shù)據(jù)頻繁的變更,可能會導致Redis和Caffeine數(shù)據(jù)不一致的問題,所以本文給大家介紹了Redis+Caffeine多級緩存數(shù)據(jù)一致性解決方案,需要的朋友可以參考下
    2024-12-12
  • Redis存取序列化與反序列化性能問題詳解

    Redis存取序列化與反序列化性能問題詳解

    這篇文章主要給大家介紹了關于Redis存取序列化與反序列化性能問題的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • 使用Redis實現(xiàn)用戶積分排行榜的教程

    使用Redis實現(xiàn)用戶積分排行榜的教程

    這篇文章主要介紹了使用Redis實現(xiàn)用戶積分排行榜的教程,包括一個用PHP腳本進行操作的例子,需要的朋友可以參考下
    2015-04-04
  • redis客戶端實現(xiàn)高可用讀寫分離的方式詳解

    redis客戶端實現(xiàn)高可用讀寫分離的方式詳解

    基于sentienl 獲取和動態(tài)感知 master、slaves節(jié)點信息的變化,我們的讀寫分離客戶端就能具備高可用+動態(tài)擴容感知能力了,接下來通過本文給大家分享redis客戶端實現(xiàn)高可用讀寫分離的方式,感興趣的朋友一起看看吧
    2021-07-07
  • 利用Redis?lua實現(xiàn)高效讀寫鎖的代碼實例

    利用Redis?lua實現(xiàn)高效讀寫鎖的代碼實例

    這篇文章給大家介紹了如何利用Redis?lua實現(xiàn)高效的讀寫鎖,讀寫鎖的好處就是能幫助客戶讀到的數(shù)據(jù)一定是最新的,寫鎖是排他鎖,而讀鎖是一個共享鎖,需要的朋友可以參考下
    2024-01-01
  • Redis中的數(shù)據(jù)結構跳表詳解

    Redis中的數(shù)據(jù)結構跳表詳解

    跳表是一種基于并聯(lián)的鏈表結構,用于在有序元素序列中快速查找元素的數(shù)據(jù)結構,本文給大家介紹Redis中的數(shù)據(jù)結構跳表,感興趣的朋友跟隨小編一起看看吧
    2024-06-06
  • Redis集群的搭建圖文教程

    Redis集群的搭建圖文教程

    下面小編就為大家分享一篇Redis集群的搭建圖文教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-11-11

最新評論