緩存和數據庫一致性更新原則 緩存是一種高性能的內存的存儲介質,它通過key-value的形式來存儲一些數據;而數據庫是一種持久化的存儲復雜關系的存儲介質。使用緩存和數據庫結合的模式就使得軟件系統的性能得到了更好的提升(更好的存儲介質,更貼近請求的存儲距離,比如本地緩存),並且給系統提供了更簡便 ...
一 緩存更新場景介紹 緩存是一種提高系統讀性能的常見技術,對於讀多寫少的應用場景,我們經常使用緩存來進行優化。 例如對於用戶的余額信息表account uid, money ,業務上的需求是: 查詢用戶的余額,SELECT money FROM account WHERE uid XXX,占 的請求 更改用戶余額,UPDATE account SET money XXX WHERE uid XXX ...
2014-06-13 09:49 0 7291 推薦指數:
緩存和數據庫一致性更新原則 緩存是一種高性能的內存的存儲介質,它通過key-value的形式來存儲一些數據;而數據庫是一種持久化的存儲復雜關系的存儲介質。使用緩存和數據庫結合的模式就使得軟件系統的性能得到了更好的提升(更好的存儲介質,更貼近請求的存儲距離,比如本地緩存),並且給系統提供了更簡便 ...
看到好些人在寫更新緩存數據代碼時,先刪除緩存,然后再更新數據庫,而后續的操作會把數據再裝載的緩存中。然而,這個是邏輯是錯誤的。試想,兩個並發操作,一個是更新操作,另一個是查詢操作,更新操作刪除緩存后,查詢操作沒有命中緩存,先把老數據讀出來后放到緩存中,然后更新操作更新了數據庫 ...
本文主要討論這么幾個問題: (1)啥時候數據庫和緩存中的數據會不一致 (2)不一致優化思路 (3)如何保證數據庫與緩存的一致性 一、需求緣起 上一篇《緩存架構設計細節二三事》(點擊查看)引起了廣泛的討論,其中有一個結論:當數據發生變化 ...
造成數據不一致。 方案二:更新數據庫,更新緩存這種緩存更新策略俗稱雙寫,存在問題是:並發更新數據庫場景 ...
將不一致分為三種情況: 1. 數據庫有數據,緩存沒有數據; 2. 數據庫有數據,緩存也有數據,數據不相等; 3. 數據庫沒有數據,緩存有數據。 在討論這三種情況之前,先說明一下我使用緩存的策略,也是大多數人使用的策略,叫做 Cache Aside Pattern。簡而言之 ...
針對這兩點問題,一共可以分為四種方案: 1、先更新緩存,再更新數據庫; 2、先更新數據庫,再更新緩存; 3、先淘汰緩存,再更新數據庫; 4、先更新數據庫,再淘汰緩存。 更新緩存、淘汰緩存的優缺點: 淘汰緩存 優點:操作簡單,不用關心更新操作,直接將緩存中的舊值 ...
一致? 要解答這個問題,我們首先來看不一致的幾種情況。我將不一致分為三種情況: 1. 數據庫有 ...
幾年前,我在看博客的時候,看到有一篇博客的標題就是關於數據庫,緩存一致性的,不以為然,直接跳過去了,心想,這么簡單的問題還討論個鬼啊。這種想法持續了很久,直到某天,我看到越來越多的人都在討論數據庫,緩存一致性的問題,才好好的看了下博客,才發現原來數據庫,緩存一致性真不是一個簡單的問題。今天 ...