如何保證緩存與數(shù)據(jù)庫雙寫時的數(shù)據(jù)一致性?
24、常見的數(shù)據(jù)優(yōu)化方案你了解嗎?
一、緩存雙淘汰法
先淘汰緩存再寫數(shù)據(jù)庫往消息總線esb發(fā)送一個淘汰消息,發(fā)送立即返回。寫請求的處理時間幾乎沒有增加,這個方法淘汰了緩存兩次。因此被稱為“緩存雙淘汰法“,而在消息總線下游,有一個異步淘汰緩存的消費者,在拿到淘汰消息在1s后淘汰緩存,這樣,即使在一秒內(nèi)有臟數(shù)據(jù)入緩存,也能夠被淘汰掉。
二、異步淘汰緩存
上述的步驟,都是在業(yè)務(wù)線里面執(zhí)行,新增一個線下的讀取binlog異步淘汰緩存模塊,讀取binlog總的數(shù)據(jù),然后進行異步淘汰。
這里簡單提供一個思路
1.思路:
MySQL binlog增量發(fā)布訂閱消費+消息隊列+增量數(shù)據(jù)更新到Redis
1)讀請求走Redis:熱數(shù)據(jù)基本都在Redis
2)寫請求走MySQL: 增刪改都操作MySQL
3)更新Redis數(shù)據(jù):MySQ的數(shù)據(jù)操作binlog,來更新到Redis
2.Redis更新
1)數(shù)據(jù)操作主要分為兩塊:
一個是全量(將全部數(shù)據(jù)一次寫入到Redis)一個是增量(實時更新)
這里說的是增量,指的是 MySQL 的update、insert、delate變更數(shù)據(jù)。
這樣一旦MySQL中產(chǎn)生了新的寫入、更新、刪除等操作,就可以把binlog相關(guān)的消息推送至Redis,Redis再根據(jù)binlog中的記錄,對Redis進行更新,就無需在從業(yè)務(wù)線去操作緩存內(nèi)容。
結(jié)語
你學廢了嗎?祝你今天卷的愉快~

請輸入評論內(nèi)容...
請輸入評論/評論長度6~500個字
最新活動更多
-
即日-9.1立即下載>> 【限時下載】ADI中國三十周年感恩回饋助力企業(yè)升級!
-
即日-9.16點擊進入 >> 【限時福利】TE 2025國際物聯(lián)網(wǎng)展·深圳站
-
10月23日立即報名>> Works With 開發(fā)者大會深圳站
-
10月24日立即參評>> 【評選】維科杯·OFweek 2025(第十屆)物聯(lián)網(wǎng)行業(yè)年度評選
-
11月27日立即報名>> 【工程師系列】汽車電子技術(shù)在線大會
-
12月18日立即報名>> 【線下會議】OFweek 2025(第十屆)物聯(lián)網(wǎng)產(chǎn)業(yè)大會
推薦專題
- 1 阿里首位程序員,“掃地僧”多隆已離職
- 2 先進算力新選擇 | 2025華為算力場景發(fā)布會暨北京xPN伙伴大會成功舉辦
- 3 宇樹機器人撞人事件的深度剖析:六維力傳感器如何成為人機安全的關(guān)鍵屏障
- 4 清華跑出具身智能獨角獸:給機器人安上眼睛和大腦,融資近20億
- 5 特朗普要求英特爾首位華人 CEO 辭職
- 6 踢館大廠和微軟,剖析WPS靈犀的AI實用主義
- 7 騰訊 Q2 財報亮眼:AI 已成第二增長曲線
- 8 谷歌吹響AI沖鋒號,AI還有哪些機會
- 9 蘋果把身家押在Siri上:一場輸不起的自我革命
- 10 共探合作新機遇!江門市新會區(qū)(深圳)“AI + 機器人” 產(chǎn)業(yè)對接會成功舉辦