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

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

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

一、普通刪除

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

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

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

1. 先刪除緩存

在這里插入圖片描述

問(wèn)題:此時(shí)緩存有了舊數(shù)據(jù),在下次修改此數(shù)據(jù)之前,所有請(qǐng)求獲取的都是舊數(shù)據(jù),導(dǎo)致讀寫不一致

2. 后刪除緩存

在這里插入圖片描述

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

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

二、雙刪策略

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

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

1. 普通雙刪

在這里插入圖片描述

問(wèn)題:因?yàn)榫€程調(diào)度一些問(wèn)題導(dǎo)致查詢后寫入緩存停止,會(huì)導(dǎo)致舊緩存依舊存在

2. 延遲雙刪

在這里插入圖片描述

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

問(wèn)題:延時(shí)時(shí)長(zhǎng)問(wèn)題,時(shí)間太長(zhǎng)導(dǎo)致性能下降,時(shí)間太短又會(huì)跟普通雙刪一樣

三、讀寫鎖

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

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

    在這里插入圖片描述

四、異步通知

1. 消息中間件異步通知

在這里插入圖片描述

  • 對(duì)于這個(gè)博主認(rèn)為是把延遲雙刪的延遲給優(yōu)化了,不再占用本線程的時(shí)間,只不過(guò)部分請(qǐng)求會(huì)導(dǎo)致舊數(shù)據(jù)。

2.Canal

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

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

五. 總結(jié)

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

結(jié)語(yǔ)

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

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

相關(guān)文章

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

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

    在Kubernetes中部署Redis集群面臨挑戰(zhàn),因?yàn)槊總€(gè)Redis實(shí)例都依賴于一個(gè)配置文件,該文件可以跟蹤其他集群實(shí)例及其角色。需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-06-06
  • Redis中的慢日志

    Redis中的慢日志

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    Windows系統(tǒng)設(shè)置Redis服務(wù)使其開(kāi)機(jī)自啟動(dòng)

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

最新評(píng)論