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

Redis分布式緩存-Redis持久化詳解

 更新時間:2024年12月25日 14:38:21   作者:明礬java  
RDB持久化將內(nèi)存數(shù)據(jù)快照到磁盤,用于故障恢復(fù);AOF持久化記錄每個寫命令,提供數(shù)據(jù)安全性,兩者各有優(yōu)缺點(diǎn),可根據(jù)需求選擇或結(jié)合使用

RDB持久化

RDB全稱Redis Database Backup file(Redis數(shù)據(jù)備份文件),也被叫做Redis數(shù)據(jù)快照。簡單來說就是把內(nèi)存中的所有數(shù)據(jù)都記錄到磁盤中。

當(dāng)Redis實(shí)例故障重啟后,從磁盤讀取快照文件,恢復(fù)數(shù)據(jù)??煺瘴募Q為RDB文件,默認(rèn)是保存在當(dāng)前運(yùn)行目錄。

執(zhí)行時機(jī)

RDB持久化在四種情況下會執(zhí)行:

  1. 執(zhí)行save命令
  2. 執(zhí)行bgsave命令
  3. Redis停機(jī)時
  4. 觸發(fā)RDB條件時

save命令

執(zhí)行下面的命令,可以立即執(zhí)行一次RDB:由Redis主進(jìn)程來執(zhí)行RDB,會阻塞所有命令,跟mysql的全局鎖類似,會直接阻塞所有命令,只有在數(shù)據(jù)遷移才會用到。

bgsave命令

這個命令執(zhí)行后會開啟獨(dú)立進(jìn)程完成RDB,主進(jìn)程可以持續(xù)處理用戶請求,不受影響。

停機(jī)時

Redis停機(jī)時會執(zhí)行一次save命令,實(shí)現(xiàn)RDB持久化。

觸發(fā)RDB條件

# 900秒內(nèi),如果至少有1個key被修改,則執(zhí)行bgsave , 如果是save "" 則表示禁用RDB
save 900 1
save 300 10
save 60 10000

RDB原理

bgsave開始時會fork主進(jìn)程得到子進(jìn)程,子進(jìn)程共享主進(jìn)程的內(nèi)存數(shù)據(jù)。這里fork所復(fù)制的數(shù)據(jù),只是復(fù)制主進(jìn)程的頁表(內(nèi)存的映射,相當(dāng)于指針),并不是真正的數(shù)據(jù),速度較快,創(chuàng)建子進(jìn)程的過程不會太久,完成fork后讀取內(nèi)存數(shù)據(jù)并寫入RDB 文件。

fork采用的是copy-on-write技術(shù):

  • 當(dāng)主進(jìn)程執(zhí)行讀操作時,訪問共享內(nèi)存;
  • 當(dāng)主進(jìn)程執(zhí)行寫操作時,則會拷貝一份數(shù)據(jù),執(zhí)行寫操作。

小結(jié)

RDB方式bgsave的基本流程:

  • fork主進(jìn)程得到一個子進(jìn)程,共享內(nèi)存空間,從而異步處理磁盤IO這種耗時較長的過程
  • 子進(jìn)程讀取內(nèi)存數(shù)據(jù)并寫入新的RDB文件
  • 用新RDB文件替換舊的RDB文件

RDB會在什么時候執(zhí)行?save 60 1000代表什么含義?

  • 默認(rèn)是服務(wù)停止時
  • 代表60秒內(nèi)至少執(zhí)行1000次修改則觸發(fā)RDB

RDB的缺點(diǎn):

  • RDB執(zhí)行間隔時間長,兩次RDB之間寫入數(shù)據(jù)有丟失的風(fēng)險
  • fork子進(jìn)程、壓縮、寫出RDB文件都比較耗時

AOF持久化

AOF原理

AOF全稱為Append Only File(追加文件)。Redis處理的每一個寫命令都會記錄在AOF文件,可以看做是命令日志文件。類似于Mysql的undo log用于記錄命令的邏輯而非具體的數(shù)據(jù)。

AOF配置

AOF默認(rèn)是關(guān)閉的,需要修改redis.conf配置文件來開啟AOF:

# 是否開啟AOF功能,默認(rèn)是no
appendonly yes
# AOF文件的名稱
appendfilename "appendonly.aof"

AOF的命令記錄的頻率也可以通過redis.conf文件來配:

# 表示每執(zhí)行一次寫命令,立即記錄到AOF文件
appendfsync always
# 寫命令執(zhí)行完先放入AOF緩沖區(qū),然后表示每隔1秒將緩沖區(qū)數(shù)據(jù)寫到AOF文件,是默認(rèn)方案
appendfsync everysec
# 寫命令執(zhí)行完先放入AOF緩沖區(qū),由操作系統(tǒng)決定何時將緩沖區(qū)內(nèi)容寫回磁盤
appendfsync no

三種策略對比:

AOF文件重寫

因?yàn)槭怯涗浢?,AOF文件會比RDB文件大的多。而且AOF會記錄對同一個key的多次寫操作,但只有最后一次寫操作才有意義。通過執(zhí)行bgrewriteaof命令,可以讓AOF文件執(zhí)行重寫功能,用最少的命令達(dá)到相同效果。

如圖,AOF原本有三個命令,但是

set num 123 和 set num 666

都是對num的操作,第二次會覆蓋第一次的值,因此第一個命令記錄下來沒有意義。

所以重寫命令后,AOF文件內(nèi)容就是:

mset name jack num 666

Redis也會在觸發(fā)閾值時自動去重寫AOF文件。閾值也可以在redis.conf中配置:

# AOF文件比上次文件 增長超過多少百分比則觸發(fā)重寫
auto-aof-rewrite-percentage 100
# AOF文件體積最小多大以上才觸發(fā)重寫
auto-aof-rewrite-min-size 64mb

RDB與AOF對比

RDB和AOF各有自己的優(yōu)缺點(diǎn),如果對數(shù)據(jù)安全性要求較高,在實(shí)際開發(fā)中往往會結(jié)合兩者來使用。

總結(jié)

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 如何基于Session實(shí)現(xiàn)短信登錄功能

    如何基于Session實(shí)現(xiàn)短信登錄功能

    對比起Cookie,Session是存儲在服務(wù)器端的會話,相對安全,并且不像Cookie那樣有存儲長度限制,下面這篇文章主要給大家介紹了關(guān)于如何基于Session實(shí)現(xiàn)短信登錄功能的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • Redis不同數(shù)據(jù)類型使用場景代碼實(shí)例

    Redis不同數(shù)據(jù)類型使用場景代碼實(shí)例

    這篇文章主要介紹了Redis不同數(shù)據(jù)類型使用場景代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-12-12
  • 談?wù)凴edis分布式鎖的正確實(shí)現(xiàn)方法

    談?wù)凴edis分布式鎖的正確實(shí)現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于Redis分布式鎖的正確實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Redis具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 基于Redis驗(yàn)證碼發(fā)送及校驗(yàn)方案實(shí)現(xiàn)

    基于Redis驗(yàn)證碼發(fā)送及校驗(yàn)方案實(shí)現(xiàn)

    本文主要介紹了基于Redis驗(yàn)證碼發(fā)送及校驗(yàn)方案實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • Redis Cluster 集群搭建你會嗎

    Redis Cluster 集群搭建你會嗎

    這篇文章主要介紹了Redis Cluster 集群搭建過程,本文分步驟通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-08
  • Satoken+Redis實(shí)現(xiàn)短信登錄、注冊、鑒權(quán)功能

    Satoken+Redis實(shí)現(xiàn)短信登錄、注冊、鑒權(quán)功能

    這篇文章主要介紹了Satoken+Redis實(shí)現(xiàn)短信登錄、注冊、鑒權(quán)功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-01-01
  • 一文帶你了解Redis中RDB與AOF的區(qū)別

    一文帶你了解Redis中RDB與AOF的區(qū)別

    Redis 在持久化時,給我們提供了兩種方式,這兩種方式就是 RDB 與 AOF,那這兩種方式有什么區(qū)別呢,本文就帶大家詳細(xì)的了解一下二者的區(qū)別,需要的朋友可以參考下
    2023-06-06
  • python中使用redis用法詳解

    python中使用redis用法詳解

    Redis擁有豐富的數(shù)據(jù)結(jié)構(gòu),擁有事務(wù)功能,保證命令的原子性。由于是內(nèi)存數(shù)據(jù)庫,讀寫非常高速,可達(dá)10w/s的評率,所以一般應(yīng)用于數(shù)據(jù)變化快、實(shí)時通訊、緩存等。這篇文章給大家講解一下Python如何使用Redis,并進(jìn)行相關(guān)的實(shí)戰(zhàn)操作。
    2022-12-12
  • 深入解析Redis的LRU與LFU算法實(shí)現(xiàn)

    深入解析Redis的LRU與LFU算法實(shí)現(xiàn)

    這篇文章主要重點(diǎn)介紹了Redis的LRU與LFU算法實(shí)現(xiàn),并分析總結(jié)了兩種算法的實(shí)現(xiàn)效果以及存在的問題,并闡述其優(yōu)劣特性,感興趣的小伙伴跟著小編一起來看看吧
    2023-07-07
  • Redis分布式限流的幾種實(shí)現(xiàn)

    Redis分布式限流的幾種實(shí)現(xiàn)

    分布式限流是指通過將限流策略嵌入到分布式系統(tǒng)中,以控制流量或保護(hù)服務(wù),本文就來介紹一下Redis分布式限流的幾種實(shí)現(xiàn),感興趣的可以了解一下
    2023-12-12

最新評論