Redis 數據持久化之RDB

Redis數據持久化策略

在這里插入圖片描述

持久化策略之RDB

在這里插入圖片描述

RDB:在指定的時間間隔,執行數據集的時間點快照。
實現類似照片記錄效果的方式,就是把某一時刻的數據和狀態以文件的形式寫到磁盤上,也就是讀快照。這樣一來即使故障宕機,快照文件也不會丟失,數據的可靠性也就能得到保證。這個快照文件就稱為RDB文件dump.rdb)。其中,RDB就是Redis DataBase的縮寫。通俗點說就是在指定的時間間隔內將內存中的數據集快照寫入磁盤,也就是行話講的Snapshot內存快照,它恢復時再將硬盤快照文件直接讀回到內存里

RDB的持久化:6與7的配置是存在一定區別的
在這里插入圖片描述
Redis 6.X中redis.conf中的配置快照部分,SNAPSHOTTING
在這里插入圖片描述
Redis6.0.16 之前的配置情況,在Redis.conf配置文件中的SNAPSHOTTING下配置save參數,來觸發Redis的RDB持久化條件。比如save m n :表示m秒內數據集存在n次修改時,自動觸發bgsave
在這里插入圖片描述
Redis 6.2以及7之后變化頻率發生了變化
在這里插入圖片描述
如何利用dump文件進行數據恢復?
在這里插入圖片描述
自動備份:
將備份文件(dump.rdb)移動到redis安裝目錄并啟動服務即可恢復數據。
備份成功后故意用flushdb清空redis,看看是否可以恢復數據?執行flushall/flushdb命令也會產生dump.rdb文件,但里面是空的,無意義。
物理恢復,一定服務和備份分機隔離
備注:不可以把備份文件dump.rdb和生產redis服務器放在同一臺機器,必須分開各自存儲,以防生產機物理損壞后備份文件也掛了。
手動備份:save與bgsave
redis提供了兩個命令來生成RDB文件,分別是save和bgsave(默認)
save
在這里插入圖片描述

save命令在主程序中執行會阻塞當前redis服務器,直到持久化工作完成執行save命令期間,Redis不能處理其他命令,線上禁止使用
在這里插入圖片描述

bgsave(默認)
在這里插入圖片描述

redis會在后臺異步進行快照操作,不阻塞快照同時還可以響應客戶端請求,該觸發方式會fork一個子進程,由子進程復制持久化過程
在這里插入圖片描述
fork是什么? 從linux角度看,fork()會產生一個和父進程完全相同的子進程,但子進程在此后多會exec系統調用,出于效率的考慮,盡量避免膨脹。
lastsave 可以通過lastsave命令獲取最后一次成功執行快照的時間
在這里插入圖片描述
時間戳轉化
在這里插入圖片描述
RDB的優點
在這里插入圖片描述
在這里插入圖片描述
優點總結
適合大規模的數據恢復、按照業務定時備份、對數據完整性和一致性要求不高、RDB文件在內存中的加載速度要比AOF快得多

RDB的缺點
在這里插入圖片描述
在這里插入圖片描述
缺點總結
在一定間隔時間做一次備份,所以如果redis意外down掉的化,就會丟失從當前至最近一次快照期間的數據,快照之間的數據會丟失
內存數據的全量同步,如果數據量太大會導致I/O嚴重影響服務器性能
RDB依賴于主進程的fork,在更大的數據集中,這可能會導致服務請求的瞬間延遲。fork的時候內存中的數據被克隆了一份,大致2倍的膨脹性,需要考慮
數據丟失的案例
在這里插入圖片描述
kill -9 模擬宕機
在這里插入圖片描述
redis重啟恢復數據,查看數據是否丟失
在這里插入圖片描述
如何檢測修復dump.rdb文件
在這里插入圖片描述
哪些情況會觸發RDB快照??
1.配置文件中默認的快照配置
2.手動save/bgsave命令
3.執行flushall/flushdb命令也會產生dump.rdb文件,但里面是空白的
4.執行shutdown且沒有設置開啟AOF持久化
5.主從復制時,主節點自動觸發

如何禁用快照??
動態所有停止RDB保存規則的方法:

redis-cli config set save ""

配置文件快照禁用的方式
在這里插入圖片描述
RDB優化配置項
相關命令
在這里插入圖片描述
stop-writes-on-bgsave-error
在這里插入圖片描述
默認yes。 如果配置成no,表示你不在乎數據不一致或者有其他的手段發現和控制這種不一致,那么在快照寫入失敗時,也能確保redis繼續接受新的寫請求

rdbcompression
在這里插入圖片描述
默認yes 。 對于存儲到磁盤中的快照,可以設置是否進行壓縮存儲。如果是的話,redis會采用LZF算法進行壓縮。如果你不想消耗CPU來進行壓縮的話,可以設置為關閉此功能

rdbchecksum
在這里插入圖片描述
rdb-del-sync-files
在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/72166.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/72166.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/72166.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

數據分析與AI丨AI Fabric:數據和人工智能架構的未來

AI Fabric 架構是模塊化、可擴展且面向未來的,是現代商業環境中企業實現卓越的關鍵。 在當今商業環境中,數據分析和人工智能領域發展可謂日新月異。幾乎每天都有新興技術誕生,新的應用場景不斷涌現,前沿探索持續拓展。可遺憾的是&…

MyBatis - XML 操作動態 SQL

目錄 1. 前言 2. 動態插入 2.1 if 標簽 2.2 trim 標簽 2.2.1 注解完成動態 SQL 3. 動態查詢 3.1 添加 1 1 3.2 where 標簽 4. 動態更新 4.1 set 標簽 5. foreach 標簽 6. sql 標簽 & include 標簽 1. 前言 之前博文所講的 MyBatis SQL 操作, 都必須按照注解或…

【最佳實踐】Go 責任鏈模式實現參數校驗

這里我們使用責任鏈模式來創建一個參數校驗的示例。在這個示例中,我們將實現一個簡單的責任鏈來校驗不同的參數條件。這種模式允許我們將多個校驗步驟串聯在一起,以便可以在不同的條件下進行靈活的校驗。 設計思路 接口定義 (Validator) 目的&#xff1…

深入理解Tomcat:Java Web服務器的安裝與配置

大家好!今天我們來聊聊Java Web開發中最重要的工具之一——Apache Tomcat。Tomcat是一個開源的Java Servlet容器和Web服務器,它是運行Java Web應用程序的核心環境。無論是開發、測試還是部署Java Web應用,Tomcat都是不可或缺的工具。本文將詳…

小程序酒店:如何實現智能預訂與在線支付?

在移動互聯網快速發展的今天,酒店行業面臨著前所未有的機遇與挑戰。用戶需求日益多樣化,市場競爭愈發激烈,傳統酒店預訂方式已經難以滿足現代消費者的需求。而小程序作為一種輕量化、便捷化的移動應用形式,正在成為酒店行業數字化轉型的重要工具。通過小程序開發,酒店可以…

C#實現AES-CBC加密工具類(含完整源碼及使用教程)

一、AES-CBC加密應用場景 AES(Advanced Encryption Standard)作為全球公認的安全加密標準,廣泛使用在以下場景: API通信加密:保護HTTP接口傳輸的敏感數據(如身份令牌、支付信息)文件安全存儲&…

docker-compose部署MongoDB分片集群

前言 MongoDB 使用 keyFile 進行 節點間身份驗證,我們需要先創建一個 keyFile 并確保所有副本集的節點使用相同的 keyFile。 openssl rand -base64 756 > mongo-keyfile chmod 400 mongo-keyfiledocker-compose部署分片集群 無密碼方式 # docker-compose-mongodb.yml s…

3-003:在 MySQL 中建索引時需要注意哪些事項?

在 MySQL 中創建索引時,需要注意以下事項,以確保索引高效且合理: 1. 選擇合適的索引類型 主鍵索引(PRIMARY KEY):每個表只能有一個,默認是聚簇索引。唯一索引(UNIQUE)&…

在 Linux 系統中,區分**磁盤(物理/虛擬存儲設備)和分區(磁盤的邏輯劃分)

在 Linux 系統中,區分**磁盤(物理/虛擬存儲設備)和分區(磁盤的邏輯劃分)**是管理存儲的基礎。以下是詳細的區分方法和操作示例: 一、通過設備命名規則區分 Linux 中磁盤和分區的命名遵循特定規則&#xff…

MongoDB中的游標(Cursor)

游標(Cursor)在MongoDB中是一個重要的概念,它用于逐條遍歷查詢結果集,特別適用于處理大量數據時。 一、游標的定義與作用 定義: 游標是一種能從數據記錄的結果集中每次提取一條記錄的機制。在MongoDB中,游…

【從零開始學習計算機科學】編譯原理(七)運行時刻環境

【從零開始學習計算機科學】編譯原理(七)運行時刻環境 運行時刻環境存儲組織空間的棧式分配活動樹活動記錄和控制棧簡單棧式存貯分配C語言的過程調用和過程返回時的存貯管理堆式存儲分配堆式存儲分配的功能垃圾回收基于跟蹤的垃圾回收短停頓垃圾回收運行時刻環境 存儲組織 …

2025-03-08 學習記錄--C/C++-PTA 習題10-1 判斷滿足條件的三位數

合抱之木&#xff0c;生于毫末&#xff1b;九層之臺&#xff0c;起于累土&#xff1b;千里之行&#xff0c;始于足下。&#x1f4aa;&#x1f3fb; 一、題目描述 ?? 裁判測試程序樣例&#xff1a; #include <stdio.h> #include <math.h>int search( int n );int…

【ArcGIS】地理坐標系

文章目錄 一、坐標系理論體系深度解析1.1 地球形態的數學表達演進史1.1.1 地球曲率的認知變化1.1.2 參考橢球體參數對比表 1.2 地理坐標系的三維密碼1.2.1 經緯度的本質1.2.2 大地基準面&#xff08;Datum&#xff09;的奧秘 1.3 投影坐標系&#xff1a;平面世界的誕生1.3.1 投…

DeepSeek刷力扣輔助題單 存留記錄

最近感覺被什么東西阻擋了腳步,經大佬建議,做算法題提升一下思維 首先,我不認為算法題要死磕,因為我沒有那個天賦,但是我還是要嘴硬一下 其次,我沒有計算機基礎的學習背景,因為我是修飛機專升本來的自動化專業,24年七月幾乎零基礎學習Unity 和 C#,努力學習到現在感覺已經盡力了…

化工廠防爆氣象站:為石油化工、天然氣等領域提供安全保障

【TH-FB02】在石油化工、天然氣等高危行業中&#xff0c;安全生產是至關重要的。這些行業常常面臨著易燃易爆、有毒有害等潛在風險&#xff0c;因此&#xff0c;對氣象條件的監測和預警顯得尤為重要。化工廠防爆氣象站作為一種專門設計用于這些特殊環境的氣象監測設備&#xff…

《MySQL數據庫從零搭建到高效管理|庫的基本操作》

目錄 一、數據庫的操作 1.1 展示數據庫 1.2 創建數據庫 1.3 使用數據庫 1.4 查看當前數據庫 1.5 刪除數據庫 1.6 小結 二、常用數據類型 2.1 數值類型 2.2 字符串類型 2.3 日期類型 一、數據庫的操作 打開MySQL命令行客戶端&#xff0c;安裝完MySQL后會有兩個客戶端…

計算機考研C語言

C語言程序設計從入門到精通【2025完整版】考研復試 嵌入式 計算機二級 軟考 專升本也適用_嗶哩嗶哩_bilibili 1、第一個C程序 helloC #include <stdio.h>int main(){printf("hehe");return 0;}每個C語言程序不管有多少行代碼&#xff0c;都是從main函數開始執…

力扣hot100二刷——鏈表

第二次刷題不在idea寫代碼&#xff0c;而是直接在leetcode網站上寫&#xff0c;“逼”自己掌握常用的函數。 標志掌握程度解釋辦法?Fully 完全掌握看到題目就有思路&#xff0c;編程也很流利??Basically 基本掌握需要稍作思考&#xff0c;或者看到提示方法后能解答???Sl…

Word 小黑第2套

對應大貓42 Word1 從文件中導入新樣式 樣式組 -管理樣式 -導入導出 -關閉Normal文件 -打開文件 -修改文件 -選中所需 -復制 調整字符寬度 調整字符間距 -字體組 加寬 適當修改磅值 文字效果通過文字組修改 另起一頁&#xff0c;分隔符&#xff08;布局 -分隔符 -分節符 -下一…

iTextSharp-PDF批量導出

HTML轉PDF批量導出速度太慢且使用Spire.pdf.dll限制頁簽10后需要開通會員才能使用-做出優化 環境&#xff1a;U9 - UI插件 需求&#xff1a;選擇需要導出的客戶查詢對應對賬數據批量導出PDF并彈出下載框保存到默認位置 using System; using System.Collections.Generic; us…