網站首頁 編程語言 正文
? | 內存淘汰 | 超時剔除 | 主動更新 |
---|---|---|---|
說明 | 不用自己維護,利用Redis的內存淘汰機制,當內存不足時自動淘汰部分數據。下次查詢時更新緩存 | 給緩存數據添加TTL時間,到期后自動刪除緩存,下次查詢時更新緩存 | 編寫業務邏輯,在修改數據的同時,更新緩存 |
一致性 | 差 | 一般 | 好 |
維護成本 | 無 | 低 | 高 |
業務場景需求:
- 在基本不會更新數據的情況下可以使用內存淘汰機制
- 在頻繁更新數據的情況下可以使用主動更新,并以超時剔除作為兜底方案。
主動更新的三種方法
- Cache Aside Pattern:由緩存的調用者,在更新數據庫的同時更新緩存
- Read/Write Through Pattern:緩存和數據庫整合為一個服務,由服務來維護一致性。調用者調用該服務,無需關心緩存一致性問題。
優點:整合的服務保證了數據的一致性
缺點:維護和開放成本高 - Write Behind Caching Pattern:調用者只操作緩存,由其他線程異步的將緩存數據持久化到數據庫,最終保持一致。
優點:異步更新緩存數據,效率高。例如緩存多次更新,但是更新到的緩存并沒有被使用,多次將數據持久化到數據庫就相當于進行了無用的操作,異步更新相當于將前幾次的更新合并為一次更新,因而提高了效率。
缺點:無法保證一致性,維護成本高 - 目前主流使用的Redis緩存主動更新的方法是Cache Aside Pattern
操作緩存和數據庫時需要考慮的三個問題
1.刪除緩存還是更新緩存?
- 更新緩存:每次更新數據庫都更新緩存,無效寫操作較多
- 刪除緩存:更新數據庫時讓緩存失效,查詢時再更新緩存
2.如何保證緩存與數據庫的操作的同時成功或者失敗
- 對于單體系統:將緩存與數據庫操作放在一個事務中
- 對于分布式系統:利用TCC等分布式事務方案
3.先操作緩存還是先操作數據庫
先刪除緩存,再操作數據庫
先操作數據庫,再刪除緩存
如上圖所示,兩種方案在多線程的情況下都會產生數據不一致的問題。但是在先操作數據庫再刪除緩存的情況下,要發生數據不一致的問題,需要在緩存寫入之前完成更新數據庫和刪除緩存的操作,而寫入緩存的耗時非常短。因而發生的概率相對于另一種方案更低。所以選擇先操作數據庫,再刪除緩存。
原文鏈接:https://www.cnblogs.com/xuzhuo123/p/16377551.html
相關推薦
- 2022-12-22 使用PyCharm調試程序實現過程_python
- 2023-01-21 Go語言ORM框架構造查詢條件示例詳解_Golang
- 2022-10-04 python編寫一個GUI倒計時器_python
- 2023-11-14 Docker 拉取結果為“等待連接時請求取消(等待標頭時超出客戶端超時);Error respons
- 2023-08-15 解決chrome升級后跨域跳轉cookie無法攜帶問題
- 2023-10-09 grid網格布局
- 2022-06-10 C語言中sizeof函數踩過的坑總結_C 語言
- 2022-11-18 Oracle移動數據文件不停機和停機兩種方式詳解_oracle
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支