七、Redis的持久化策略

?兩種持久化策略:

????????Redis這個緩存存放的數據是存到內存的,假如宕機了,那么就會數據丟失。如何避免這種情況呢?由此,Redis推出了兩種持久化機制。

? ? ? ? 第一種機制就是以二進制序列形式存儲數據的RDB快照,第二種機制就是以命令形式存放的aof日志。

????????那么Redis為什么不推出一種統一的持久化機制,而是采用了兩種呢?其實就是對應不同的兩種使用場景。

????????設想一種場景,Redis機器重啟時,這時候需要重新加載所有的數據來恢復內存。

????????但有一種場景,不需要重新加載數據,而只需要加載增量的數據。此時,其實就可以獲取后續增量的指令,執行這些指令,自然就能獲取所有的數據。

RDB快照原理

? ? ? ? Redis是單線程執行命令,當執行RDB快照時,會不會發送堵塞?答案是不會,RDB快照時涉及到了一個思想,寫時復制 copy on write。

? ? ? ? 執行快照嗎,其實就是執行save命令。主進程會fork一個子進程,此時,主子進程都會共享這一瞬間,相同一塊的內存空間(即操作系統的數據段)。主進程負責響應客戶端的請求,子進程負責遍歷內存數據,執行持久化。

? ? ? ? 從這個流程也可以看出來RDB的局限性,它只是保存一瞬間的快照,并不能保存全量的數據。

AOF的原理

????????一句話,AOF的原理就是記錄Redis服務器的順序的寫指令。當然,由于其記錄的是指令,會占據太多無用的內存空間。因此,時間一長,就不得不清理這些冗余的指令,這就觸發了redis的aof重寫,即:bgrewriteaof指令。

? ? ? ? AOF的重寫,也如同rdb快照一樣,都是讓子進程執行的,通過精簡各種指令,減少重復指令等減少內存占用。

? ? ? ? AOF形式持久化的缺點就是,當恢復數據時,由于單線程順序執行aof的指令,其回復速度非常慢。

混合持久化

? ? ? ? 前面的介紹可以看出來,RDB占據的空間相對小,并且恢復起來速度快,但會丟失數據。AOF可以保存到指令級的數據,但由于其順序執行指令才能持久化數據。那么混合持久化應運而生,將增量的AOF文件和RDB快照結合一起,汲取兩者的優點。

????????

????????

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

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

相關文章

GVim-vimrc 字體縮放與界面優化配置

GVim-vimrc 字體縮放與界面優化配置 文章目錄 GVim-vimrc 字體縮放與界面優化配置背景問題解決方案1. 字體大小調整函數增加字體大小函數減少字體大小函數 2. 快捷鍵映射3. 自定義命令 附加界面優化光標行列高亮 完整配置使用技巧 背景問題 在使用Vim編輯器時,我們…

Oracle|Oracle SQL*Plus 配置上下翻頁功能

在數據庫管理工作中,高效的命令行操作體驗對于提升工作效率至關重要。本文將詳細介紹如何通過安裝 rlwrap 工具并進行環境變量配置,讓 SQL*Plus 獲得現代化的命令行體驗,助力數據庫操作效率的大幅提升。 一、安裝準備:創建軟件目…

PowerShell讀取CSV并遍歷組數組

在 PowerShell 中,從 CSV 文件獲取 Group 列的數據并遍歷輸出,可以按照以下步驟操作: 步驟說明: 讀取 CSV 文件:使用 Import-Csv 命令加載 CSV 數據。 提取 Group 數組:通過管道操作 | Select-Object -Ex…

【unitrix】 3.7 類型級加一計算(Add1.rs)

一、源碼 這段代碼實現了一個類型級別的加法操作(Add1 trait),允許在編譯時對數字類型進行加一操作。它使用了類型系統來表示數字(如 Z0、P1、N1 等),并定義了它們的加一行為。 //! 加一操作特質實現 / I…

據字典是什么?和數據庫、數據倉庫有什么關系?

目錄 一、數據字典的定義及作用 1. 對于數據開發者 2. 對于業務人員 3. 對于數據管理員 二、數據字典的組成 1. 數據項 2. 數據結構 3. 數據流 4. 數據存儲 5. 處理過程 三、數據字典與數據庫的關系 1. 數據字典是數據庫的重要組成部分 2. 數據字典為數據庫設計和…

附加日志會跟隨著expdp一起導出嗎

數據泵在導出數據表時會不會帶著附加日志一起導出,可以使用數據泵導入參數sqlfile進行sql追蹤。 實驗 1.新建測試表 SQL> create table Benjamin.tb_test (id int); Table created.SQL> alter table Benjamin.tb_test add supplemental log data(all) colu…

Python漂浮的愛心

系列文章 序號直達鏈接Tkinter1Python李峋同款可寫字版跳動的愛心2Python跳動的雙愛心3Python藍色跳動的愛心4Python動漫煙花5Python粒子煙花Turtle1Python滿屏飄字2Python藍色流星雨3Python金色流星雨4Python漂浮愛心5Python愛心光波①6Python愛心光波②7Python滿天繁星8Pytho…

3、做中學 | 二年級上期 Golang數據類型和常量/變量聲明使用

一、基本數據類型 在 Go 編程語言中,數據類型用于聲明函數和變量。 數據類型的出現是為了把數據分成所需內存大小不同的數據,編程的時候需要用大數據的時候才需要申請大內存,就可以充分利用內存。 Go 基本數據類型 類別類型描述零值示例取…

php5 與 mysql8的兼容問題

php5 與 mysql8的兼容問題 環境 Linux: ubuntu20.04 Mysql&#xff1a; 8.0.33 Php: 5.6 代碼 # cat test.php <?php$link mysqli_connect("127.0.0.1", "root", "123456");if ($link) {echo "ok"; } else {echo "fail&…

從0開始學linux韋東山教程Linux驅動入門實驗班(1)

本人從0開始學習linux&#xff0c;使用的是韋東山的教程&#xff0c;在跟著課程學習的情況下的所遇到的問題的總結,理論雖枯燥但是是基礎。本人將前幾章的內容大致學完之后&#xff0c;考慮到后續驅動方面得更多的開始實操&#xff0c;后續的內容將以韋東山教程Linux驅動入門實…

MSPM0G3507學習筆記(二) 超便捷配置led與按鍵

電賽備賽中&#xff0c;打算系統過一遍MSPM0G3507的各個部分&#xff0c;同時把過程記錄下來。本系列以代碼全部能用復用性、可移植性高為目的。本系列所有的代碼會開源至github&#xff0c;如果覺得有用&#xff0c;請點個贊/給我的github倉庫點一顆star吧。 github地址&…

day03-微服務01

【黑馬程序員SpringCloud微服務技術棧實戰教程&#xff0c;涵蓋springcloud微服務架構Nacos配置中心分布式事務等】 暫時無法在飛書文檔外展示此內容 之前我們學習的項目一是單體項目&#xff0c;可以滿足小型項目或傳統項目的開發。而在互聯網時代&#xff0c;越來越多的一線…

嵌入式Linux系統內存占用率高的原因、后果與防控全解析

作者&#xff1a;嵌入式Jerry 【歡迎關注“嵌入式Jerry”&#xff0c;獲取更多Linux/驅動/性能實戰干貨】 推薦閱讀&#xff1a;《Yocto項目實戰教程&#xff1a;高效定制嵌入式Linux系統》 京東正版促銷&#xff0c;支持作者&#xff01;https://item.jd.com/15020438.html 嵌…

【案例分享】如何用 DHTMLX Scheduler 構建靈活高效的資源調度系統?

在企業信息化進程加速的今天&#xff0c;資源調度與任務管理已成為ERP系統中的關鍵模塊。今天&#xff0c;我們帶來了一個來自 X-Interactive 的精彩應用案例&#xff0c;看他們如何借助 DHTMLX Scheduler 實現更智能的任務分配與資源規劃。 DHTMLX Scheduler 試用下載 &…

Kafka 向 TDengine 寫入數據

TDengine Kafka Connector 包含 TDengine Source Connector 和 TDengine Sink Connector 兩個插件。用戶只需提供簡單的配置文件&#xff0c;就可以將 Kafka 中指定 topic 的數據&#xff08;批量或實時&#xff09;同步到 TDengine&#xff0c;或將 TDengine 中指定數據庫的數…

智慧醫院核心引擎:IBMS 系統守護醫療環境高效與安全?

在醫療場景中&#xff0c;時間就是生命&#xff0c;效率與安全容不得分毫差錯。傳統醫院面臨著設備管理分散、應急響應遲緩、能耗居高不下等難題&#xff0c;嚴重制約醫療服務質量與運營效率。而 IBMS 系統&#xff0c;作為智慧醫院的核心引擎&#xff0c;以尖端科技重塑醫療環…

平均性能提升70%,蓋雅工場基于騰訊云數據倉庫TCHouse-D構建實時報表平臺

點擊藍字? 關注我們 本文共計3569字 預計閱讀時長11分鐘 導語 騰訊云數據倉庫TCHouse-D助力蓋雅工場構建了架構簡潔、查詢高效的報表平臺。目前該平臺已經支撐了蓋雅工場上千個租戶的實時報表需求&#xff0c;報表查詢時效性整體可達亞秒級&#xff0c;相較原架構&#xff0c;…

zynq裸機開發:更改系統時間保存文件到SD卡

1、首先勾選文件系統庫 2、之后導出一個SD卡文件寫demo 3、SD卡創建或修改文件時的創建時間和修改時間是通過調用BSP包的diskio.c文件中的get_fattime函數 4、找到這段函數&#xff0c;先把他注釋掉&#xff0c;之后考到導出demo的最后一行&#xff0c;稍作修改&#xff0c…

“荔枝使”的難題怎么破:A*運輸路徑算法編程實踐

原文首發請訪問&#xff1a;https://cloud.tencent.com/developer/article/2533317 荔枝最初被稱為“離支”&#xff0c;亦作“離枝”。 這是一種非常精貴的水果&#xff0c;一旦離開枝頭&#xff0c;色澤、香氣和味道會在短時間內迅速變質。 但它又是非常美味&#xff0c;宋…

python基礎知識,以及7個練習案例

python的用途 搭建網站網絡爬蟲科學計算與大數據分析人工智能與機器學習設計動畫游戲&#xff1a;例如pygame圖形用戶接口開發&#xff1a;模塊與框架&#xff0c;如tkinter python基礎課程包含內容 自動化運維人工智能應用web開發多媒體處理自動化辦公python爬蟲 python是…