欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于Redis的讀寫一致問題

 更新時間:2023年08月13日 09:37:18   作者:愛發(fā)博客的嗯哼  
在項目使用Redis過程中,當數(shù)據(jù)更新時,我們要保證緩存和數(shù)據(jù)庫的一致性,否則會導致很多臟數(shù)據(jù)出現(xiàn),此時我們就要思考如何去進行數(shù)據(jù)更新,本文就給大家講講關(guān)于redis的讀寫一致問題,需要的朋友可以參考下

一、普通刪除

在數(shù)據(jù)更新過程中,大家無非使用兩種方法進行緩存和數(shù)據(jù)庫的更新

  • 先刪除緩存,再更新數(shù)據(jù)庫
  • 先更新數(shù)據(jù)庫,再更新緩存

那這兩種方法究竟有什么不同呢?

1. 先刪除緩存

在這里插入圖片描述

問題:此時緩存有了舊數(shù)據(jù),在下次修改此數(shù)據(jù)之前,所有請求獲取的都是舊數(shù)據(jù),導致讀寫不一致

2. 后刪除緩存

在這里插入圖片描述

問題1:在小明修改數(shù)據(jù)庫到刪除緩存這段時間,所有請求都是舊數(shù)據(jù)

問題2:如果緩存刪除失敗,后續(xù)所有請求都是舊數(shù)據(jù)(這個問題開啟事務(wù)的話,就可以解決)

二、雙刪策略

在普通刪除策略中,大家會發(fā)現(xiàn)后刪緩存策略是比較好的一種,但還是存在一點問題,所以提出了雙刪策略

關(guān)于這個地方我是存在疑問的,因為我認為雙刪并不會比后刪緩存策略更好,反而增加了一次數(shù)據(jù)庫查詢的操作。但有的博客卻提了這個策略,我就在這里提一下,大家可以在評論進行交流

1. 普通雙刪

在這里插入圖片描述

問題:因為線程調(diào)度一些問題導致查詢后寫入緩存停止,會導致舊緩存依舊存在

2. 延遲雙刪

在這里插入圖片描述

這樣的話看似把普通雙刪的問題給解決了,但并沒有完全解決,反而引發(fā)新的問題。

問題:延時時長問題,時間太長導致性能下降,時間太短又會跟普通雙刪一樣

三、讀寫鎖

讀寫鎖根據(jù)字面意思就知道是加鎖,因此效率肯定比不加鎖效率低,但是可以完全避免舊數(shù)據(jù)讀取的發(fā)生。

  • 讀寫鎖是讀讀共享,讀寫和寫寫互斥的

    在這里插入圖片描述

四、異步通知

1. 消息中間件異步通知

在這里插入圖片描述

  • 對于這個博主認為是把延遲雙刪的延遲給優(yōu)化了,不再占用本線程的時間,只不過部分請求會導致舊數(shù)據(jù)。

2.Canal

Canal是一個開源的數(shù)據(jù)庫數(shù)據(jù)增量訂閱和消費組件,用于實時捕獲數(shù)據(jù)庫的變更并將其傳遞給其他系統(tǒng)。具體而言,Canal主要用于解決數(shù)據(jù)庫之間的數(shù)據(jù)同步和實時數(shù)據(jù)分析需求。 Canal支持對MySQL、Oracle等主流數(shù)據(jù)庫進行增量數(shù)據(jù)訂閱和消費。它通過解析數(shù)據(jù)庫的日志(如MySQL的binlog或Oracle的redo log),實時捕獲數(shù)據(jù)庫的變更操作,然后將變更數(shù)據(jù)以事件的形式發(fā)送給訂閱者??梢詫⑦@些變更數(shù)據(jù)用于數(shù)據(jù)同步、實時數(shù)據(jù)倉庫、搜索引擎索引更新、緩存更新等應(yīng)用場景。 Canal的主要特性包括:

  • .數(shù)據(jù)庫無侵入:Canal通過解析數(shù)據(jù)庫日志來捕獲數(shù)據(jù)變更,不需要對數(shù)據(jù)庫進行任何修改,不會對數(shù)據(jù)庫的性能產(chǎn)生影響。
  • 實時的增量數(shù)據(jù):Canal能夠幾乎實時地捕獲到數(shù)據(jù)庫的變更操作,并以事件的形式進行傳遞,保證了數(shù)據(jù)的實時性。
  • 靈活的訂閱和過濾:Canal支持基于數(shù)據(jù)庫、表、列級別的訂閱和過濾,可以按需選擇需要同步的數(shù)據(jù),減少數(shù)據(jù)傳輸和處理的壓力。
  • 多種協(xié)議支持:Canal支持多種數(shù)據(jù)傳輸協(xié)議,如基于TCP的簡單文本協(xié)議、Kafka、RocketMQ等,可以根據(jù)具體需求選擇適合的協(xié)議進行數(shù)據(jù)傳輸。
  • 高可用和容錯:Canal支持多節(jié)點部署,通過主備模式或者集群模式來保證高可用性和容錯性。

五. 總結(jié)

總體來說這幾種方式各有優(yōu)缺點,不過現(xiàn)在主要用的就是普通刪除中的后刪緩存的方法,如果一致性要求比較高的話,可以用讀寫鎖的方式,如果沒有那么強的一致性要求,可以使用后刪緩存或者異步通知的方式。

結(jié)語

每個人都有自己獨特的才華和潛能,在這個廣袤的世界上,你的存在是有意義的。無論你是誰,你的背景如何,你所處的環(huán)境怎樣,只要你敢于跨出舒適區(qū),付出努力,追求卓越,你就能夠開創(chuàng)屬于自己的輝煌。

以上就是關(guān)于Redis的讀寫一致問題的詳細內(nèi)容,更多關(guān)于Redis讀寫一致的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • k8s部署redis cluster集群的實現(xiàn)

    k8s部署redis cluster集群的實現(xiàn)

    在Kubernetes中部署Redis集群面臨挑戰(zhàn),因為每個Redis實例都依賴于一個配置文件,該文件可以跟蹤其他集群實例及其角色。需要的朋友們下面隨著小編來一起學習學習吧
    2021-06-06
  • Redis中的慢日志

    Redis中的慢日志

    這篇文章主要介紹了Redis中的慢日志,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Redis分布式緩存-Redis持久化詳解

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

    RDB持久化將內(nèi)存數(shù)據(jù)快照到磁盤,用于故障恢復(fù);AOF持久化記錄每個寫命令,提供數(shù)據(jù)安全性,兩者各有優(yōu)缺點,可根據(jù)需求選擇或結(jié)合使用
    2024-12-12
  • redis?protocol通信協(xié)議及使用詳解

    redis?protocol通信協(xié)議及使用詳解

    這篇文章主要為大家介紹了redis?protocol通信協(xié)議及使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • 基于Redis分布式鎖的實現(xiàn)代碼

    基于Redis分布式鎖的實現(xiàn)代碼

    這篇文章主要介紹了Redis分布式鎖的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • 關(guān)于Redis解決Session共享問題

    關(guān)于Redis解決Session共享問題

    這篇文章主要介紹了Redis解決Session共享問題,本文結(jié)合實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • Redis Cluster集群數(shù)據(jù)分片機制原理

    Redis Cluster集群數(shù)據(jù)分片機制原理

    這篇文章主要介紹了Redis Cluster集群數(shù)據(jù)分片機制原理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • Redis02 使用Redis數(shù)據(jù)庫(String類型)全面解析

    Redis02 使用Redis數(shù)據(jù)庫(String類型)全面解析

    這篇文章主要介紹了Redis02 使用Redis數(shù)據(jù)庫(String類型)全面解析的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-07-07
  • 手把手教你使用redis實現(xiàn)排行榜功能

    手把手教你使用redis實現(xiàn)排行榜功能

    使用Redis中有序集合的特性來實現(xiàn)排行榜是又好又快的選擇,一般排行榜都是有實效性的,比如“用戶積分榜”,下面這篇文章主要給大家介紹了關(guān)于使用redis實現(xiàn)排行榜功能的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • Windows系統(tǒng)設(shè)置Redis服務(wù)使其開機自啟動

    Windows系統(tǒng)設(shè)置Redis服務(wù)使其開機自啟動

    Redis是一種鍵值對數(shù)據(jù)庫,也稱為內(nèi)存數(shù)據(jù)庫,因為它可以將數(shù)據(jù)存儲在內(nèi)存中,而不是在磁盤上,下面這篇文章主要給大家介紹了關(guān)于Windows系統(tǒng)設(shè)置Redis服務(wù)使其開機自啟動的相關(guān)資料,需要的朋友可以參考下
    2024-01-01

最新評論