Redis與MySQL如何保證雙寫(xiě)一致性詳解
什么是雙寫(xiě)一致性?
指的是當(dāng)我們更新了數(shù)據(jù)庫(kù)的數(shù)據(jù)之后redis中的數(shù)據(jù) 也要同步去更新。使用redis讀取數(shù)據(jù)的流程,當(dāng)用戶(hù)訪問(wèn)數(shù)據(jù)的時(shí)候,會(huì)先從緩存中讀取數(shù)據(jù),如果命中緩存的話(huà),那么直接把緩存中的數(shù)據(jù)返回給用戶(hù),如果緩存中沒(méi)有數(shù)據(jù)的話(huà),先查詢(xún)數(shù)據(jù)庫(kù)把查詢(xún)到的數(shù)據(jù)保存到緩存中,然后返回給用戶(hù)。
保證雙寫(xiě)一致性的策略
1.先更新緩存,再更新數(shù)據(jù)庫(kù)
優(yōu)點(diǎn):
- 如果數(shù)據(jù)發(fā)生變化,可以立即在緩存中反映出來(lái),提高用戶(hù)體驗(yàn)。
- 減少對(duì)數(shù)據(jù)庫(kù)的壓力,因?yàn)橹挥性跀?shù)據(jù)發(fā)生變化時(shí)才會(huì)更新數(shù)據(jù)庫(kù)。
缺點(diǎn):
- 如果緩存和數(shù)據(jù)庫(kù)之間的同步出現(xiàn)問(wèn)題,可能導(dǎo)致數(shù)據(jù)不一致。
- 需要額外的代碼來(lái)處理緩存更新和數(shù)據(jù)庫(kù)更新的順序。
應(yīng)用場(chǎng)景
這種策略通常用于提高系統(tǒng)性能。當(dāng)數(shù)據(jù)發(fā)生變化時(shí),首先將變化的數(shù)據(jù)寫(xiě)入緩存,然后由后臺(tái)進(jìn)程異步地將這些數(shù)據(jù)寫(xiě)入數(shù)據(jù)庫(kù)。這樣可以減輕數(shù)據(jù)庫(kù)的壓力,提高系統(tǒng)的響應(yīng)速度。同時(shí),如果數(shù)據(jù)庫(kù)發(fā)生故障,可以從緩存中恢復(fù)數(shù)據(jù),保證系統(tǒng)的可用性。
代碼示例
2.先更新數(shù)據(jù)庫(kù),再更新緩存
優(yōu)點(diǎn):
- 確保數(shù)據(jù)的一致性,因?yàn)榫彺媸侵苯訌臄?shù)據(jù)庫(kù)中獲取的。
- 減輕數(shù)據(jù)庫(kù)的壓力,因?yàn)橹挥性跀?shù)據(jù)發(fā)生變化時(shí)才會(huì)更新數(shù)據(jù)庫(kù)。
缺點(diǎn):
- 如果數(shù)據(jù)沒(méi)有發(fā)生變化,仍然會(huì)執(zhí)行數(shù)據(jù)庫(kù)更新操作,浪費(fèi)資源。
- 需要額外的代碼來(lái)處理緩存更新和數(shù)據(jù)庫(kù)更新的順序。
應(yīng)用場(chǎng)景
這種策略通常用于確保數(shù)據(jù)的一致性。當(dāng)數(shù)據(jù)發(fā)生變化時(shí),首先更新數(shù)據(jù)庫(kù),然后將這些變化寫(xiě)入緩存。這樣可以確保緩存中的數(shù)據(jù)始終是最新的,提高系統(tǒng)的一致性。
代碼示例
# 更新數(shù)據(jù)庫(kù) db.update() # 更新緩存 redis.update()
3.先刪除緩存,再更新數(shù)據(jù)庫(kù)
優(yōu)點(diǎn):
- 確保數(shù)據(jù)的一致性,因?yàn)榫彺媸侵苯訌臄?shù)據(jù)庫(kù)中獲取的。
- 減輕數(shù)據(jù)庫(kù)的壓力,因?yàn)橹挥性跀?shù)據(jù)發(fā)生變化時(shí)才會(huì)更新數(shù)據(jù)庫(kù)。
缺點(diǎn):
- 如果數(shù)據(jù)沒(méi)有發(fā)生變化,仍然會(huì)執(zhí)行數(shù)據(jù)庫(kù)更新操作,浪費(fèi)資源。
- 需要額外的代碼來(lái)處理緩存刪除和數(shù)據(jù)庫(kù)更新的順序。
應(yīng)用場(chǎng)景
這種策略通常用于處理緩存失效的情況。當(dāng)數(shù)據(jù)發(fā)生變化時(shí),首先刪除緩存,然后更新數(shù)據(jù)庫(kù)。這樣可以確保每次數(shù)據(jù)變更都能被正確地寫(xiě)入數(shù)據(jù)庫(kù),避免因緩存失效而導(dǎo)致的數(shù)據(jù)不一致問(wèn)題。
代碼示例
# 更新數(shù)據(jù)庫(kù) db.update() # 刪除緩存 redis.delete()
4.先更新數(shù)據(jù)庫(kù),再刪除緩存
優(yōu)點(diǎn):
- 確保數(shù)據(jù)的一致性,因?yàn)榫彺媸侵苯訌臄?shù)據(jù)庫(kù)中獲取的。
- 減輕數(shù)據(jù)庫(kù)的壓力,因?yàn)橹挥性跀?shù)據(jù)發(fā)生變化時(shí)才會(huì)更新數(shù)據(jù)庫(kù)。
缺點(diǎn):
- 如果數(shù)據(jù)沒(méi)有發(fā)生變化,仍然會(huì)執(zhí)行數(shù)據(jù)庫(kù)更新操作,浪費(fèi)資源。
- 需要額外的代碼來(lái)處理緩存刪除和數(shù)據(jù)庫(kù)更新的順序。
應(yīng)用場(chǎng)景
這種策略通常用于處理緩存過(guò)期的情況。當(dāng)數(shù)據(jù)發(fā)生變化時(shí),首先更新數(shù)據(jù)庫(kù),然后刪除緩存。這樣可以確保每次數(shù)據(jù)變更都能被正確地寫(xiě)入數(shù)據(jù)庫(kù),避免因緩存過(guò)期而導(dǎo)致的數(shù)據(jù)不一致問(wèn)題。
代碼示例
# 更新數(shù)據(jù)庫(kù) db.update() # 刪除緩存 redis.delete()
寫(xiě)在最后
到此這篇關(guān)于Redis與MySQL雙寫(xiě)一致性如何保證詳解的文章就介紹到這了,更多相關(guān)Redis與MySQL雙寫(xiě)一致性?xún)?nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Redis 緩存雙寫(xiě)一致性的解決方案
- 解決Redis的緩存與數(shù)據(jù)庫(kù)雙寫(xiě)不一致問(wèn)題
- Redis中緩存和數(shù)據(jù)庫(kù)雙寫(xiě)數(shù)據(jù)不一致的原因及解決方案
- 詳解Redis緩存與Mysql如何保證雙寫(xiě)一致
- Redis和MySQL保證雙寫(xiě)一致性的問(wèn)題解析
- redis分布式鎖解決緩存雙寫(xiě)一致性
- Redis與MySQL的雙寫(xiě)一致性問(wèn)題
- 淺談Redis跟MySQL的雙寫(xiě)問(wèn)題解決方案
- 聊一聊Redis與MySQL雙寫(xiě)一致性如何保證
- Redis的雙寫(xiě)問(wèn)題解決
相關(guān)文章
淺談MySQL使用笛卡爾積原理進(jìn)行多表查詢(xún)
這篇文章主要介紹了淺談MySQL使用笛卡爾積原理進(jìn)行多表查詢(xún), 文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07Mysql 存儲(chǔ)過(guò)程中使用游標(biāo)循環(huán)讀取臨時(shí)表
這篇文章主要介紹了Mysql 存儲(chǔ)過(guò)程中使用游標(biāo)循環(huán)讀取臨時(shí)表的方法,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫(kù),感興趣的朋友可以了解下2020-12-12MySQL數(shù)據(jù)庫(kù)修復(fù)方法(MyISAM/InnoDB)
這篇文章主要為大家整理了7條修復(fù)MySQL數(shù)據(jù)庫(kù)的方法,當(dāng)簡(jiǎn)單的重啟對(duì)數(shù)據(jù)庫(kù)不起作用,或者有表崩潰時(shí),需要的朋友可以參考下2014-06-06

SQL實(shí)現(xiàn)LeetCode(181.員工掙得比經(jīng)理多)