每日一博 - 圖解5種Cache策略

文章目錄

  • 概述
  • 讀策略
    • Cache Aside
    • Read Through
  • 寫策略
    • Write Through
    • Write Around
    • Write Back
  • 使用場景舉例

在這里插入圖片描述


概述

緩存是在系統中存儲數據的臨時存儲器,用于提高訪問速度。緩存策略定義了如何在緩存和主存之間管理數據


讀策略

Read data from the system:
🔹 Cache aside
🔹 Read through
在這里插入圖片描述


Cache Aside

概念: 應用程序負責將數據寫入和從緩存讀取,緩存不主動參與。
作用: 簡化實現,但可能導致緩存臟數據。

應用程序自己管理緩存。當需要數據時,應用程序會先在緩存中查找,如果不存在,才到數據庫中加載。加載到數據庫后,同時保存到緩存中。這種策略簡單直接,應用程序有完全控制權。但問題是代碼復雜,需要自己處理緩存失效、預熱、異步加載等問題。

在這里插入圖片描述


Read Through

概念: 數據訪問時,緩存負責檢查是否有所需數據。如果不存在,緩存負責從主存中獲取。
作用: 自動化數據加載,減少了應用程序的負擔,但可能導致讀取性能損失。

應用程序只查詢緩存,不直接訪問數據庫。如果緩存不存在,則自動從數據庫加載,然后返回給應用程序,同時更新緩存。這簡化了應用程序代碼,但也限制了應用程序直接訪問數據庫

在這里插入圖片描述


寫策略

Write data to the system:
🔹 Write around
🔹 Write back
🔹 Write through

在這里插入圖片描述

Write Through

概念: 寫入時同時到緩存和主存,確保主存和緩存中的數據一致。
作用: 數據一致性,但可能導致寫入性能較低。

數據修改請求直接寫入數據庫,同時也保存到緩存中(不是所有實現都這么做)。所以,緩存能保證和數據庫一致性。但每次寫操作都會比較慢

在這里插入圖片描述


Write Around

概念: 寫入時直接到主存,而不是到緩存。緩存只在讀取時更新。
作用: 避免緩存污染,適用于大量寫入但很少讀取的情況。

直接寫入數據庫,但不寫入緩存。這可以減輕緩存的壓力,但是讀取數據時緩存在沒有命中,需要從數據庫中加載數據然后放入緩存,性能比較差。

在這里插入圖片描述


Write Back

概念: 寫入時只到緩存,延遲寫回主存。緩存跟蹤哪些數據被修改。
作用: 提高寫入性能,但可能導致數據不一致。

在這里插入圖片描述


使用場景舉例

  1. Cache Aside:

    • 案例: 在一個電子商務網站中,商品信息被頻繁讀取,但更新并不頻繁。采用 Cache Aside 策略,應用程序在需要時直接從數據庫讀取商品信息,然后將其緩存在內存中。如果有更新,應用程序負責同時更新數據庫和緩存。
  2. Read Through:

    • 案例: 在一個社交媒體應用中,用戶的個人資料信息經常被訪問。使用 Read Through 策略,當用戶請求個人資料時,緩存會檢查是否存在,如果不存在,它將從數據庫中讀取用戶的個人資料并將其存儲在緩存中,以便下一次訪問。
  3. Write Around:

    • 案例: 在一個日志記錄系統中,日志條目的寫入頻率很高,但很少讀取。采用 Write Around 策略,應用程序直接將日志寫入主存儲,而不將其寫入緩存。緩存僅用于讀取請求,以避免緩存污染。
  4. Write Back:

    • 案例: 在一個文件系統中,用戶頻繁編輯文檔。使用 Write Back 策略,文件系統將用戶編輯的文檔暫時保存在緩存中,而不是立即寫回主存儲。只有當緩存滿或文檔不再被頻繁訪問時,才將更改寫回主存儲。
  5. Write Through:

    • 案例: 在一個金融交易系統中,每筆交易都需要確保立即寫入主存儲并更新緩存。采用 Write Through 策略,系統在執行每筆交易時同時將數據寫入緩存和主存儲,以確保數據的一致性。

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/213678.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/213678.shtml
英文地址,請注明出處:http://en.pswp.cn/news/213678.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

vue3原生方法滾動列表

效果圖 代碼 import { ref, onBeforeUnmount, onUnmounted } from "vue"; //定時器初始化 let timer ref(null); //ref綁定初始化 let roll ref(null); //等同于vue2中的beforeDestroy onBeforeUnmount(() > {//清除定時器clearTimeout(timer.value); }); //等同…

AGI時代探導開發的智能化落地之路:中國企業低代碼及無代碼應用價值報告V6

今天分享的AGI系列深度研究報告:《AGI時代探導開發的智能化落地之路:中國企業低代碼及無代碼應用價值報告V6》。 (報告出品方:甲子光年智庫) 報告共計:47頁 點擊添加圖片描述(最多60個字&…

機器學習與人工智能:一場革命性的變革

機器學習與人工智能:一場革命性的變革 人工智能的概述什么是機器學習定義解釋 數據集結構機器學習應用場景 人工智能的概述 1956年8月,在美國漢諾斯小鎮寧靜的達特茅斯學院中,約翰麥卡錫(John McCarthy)、馬文閔斯基&…

數據鏈路層的作用和三個基本問題

目錄 一. 數據鏈路層的作用二. 數據鏈路層解決的三個問題2.1 數據鏈路和幀2.2 三個基本問題(重要)2.2.1 封裝成幀2.2.2 透明傳輸2.2.3 差錯檢測 \quad 一. 數據鏈路層的作用 \quad \quad \quad 光有鏈路不能傳輸數據, 還要加上協議, 這樣才是數據鏈路 數據鏈路層的作用就是負責…

RHEL8_Linux虛擬數據優化器VDO

本章主要介紹虛擬化數據優化器 什么是虛擬數據優化器VDO創建VDO設備以節約硬盤空間 1.了解什么是VDO VDO全稱是Virtual Data Optimize(虛擬數據優化),主要是為了節省硬盤空間。 現在假設有兩個文件file1和 file2,大小都是10G。file1和 fil…

.NET 材料檢測系統崩潰分析

Windbg 分析 1. 到底是哪里的崩潰 一直跟蹤我這個系列的朋友應該知道分析崩潰第一個命令就是 !analyze -v ,讓windbg幫我們自動化異常分析。 0:033> !analyze -v CONTEXT: (.ecxr) rax00000039cccff2d7 rbx00000039c85fc2b0 rcx00000039cccff2d8 rdx000000000…

洛谷P3807 Lucas定理

傳送門: P3807 【模板】盧卡斯定理/Lucas 定理 - 洛谷 | 計算機科學教育新生態 (luogu.com.cn)https://www.luogu.com.cn/problem/P3807題干: 給定整數n,m,p 的值,求出C(nm,n)?mod p 的值。 輸入數據保證…

5分鐘搞懂K8S Pod Terminating/Unknown故障排查

Kubernetes集群中的Pod有時候會進入Terminating或Unknown狀態,本文列舉了6種可能的原因,幫助我們排查這種現象。原文: K8s Troubleshooting — Pod in Terminating or Unknown Status 有時我們會看到K8S集群中的pod進入"Terminating"或"U…

每日一練【查找總價格為目標值的兩個商品】

一、題目描述 題目鏈接 購物車內的商品價格按照升序記錄于數組 price。請在購物車中找到兩個商品的價格總和剛好是 target。若存在多種情況,返回任一結果即可。 示例 1: 輸入:price [3, 9, 12, 15], target 18 輸出:[3,15] …

成都工業學院Web技術基礎(WEB)實驗一:HTML5排版標簽使用

寫在前面 1、基于2022級計算機大類實驗指導書 2、代碼僅提供參考,前端變化比較大,按照要求,只能做到像,不能做到一模一樣 3、圖片和文字僅為示例,需要自行替換 4、如果代碼不滿足你的要求,請尋求其他的…

Python+AI實現AI繪畫

🔗 運行環境:Python 🚩 撰寫作者:左手の明天 🥇 精選專欄:《python》 🔥 推薦專欄:《算法研究》 🔐#### 防偽水印——左手の明天 ####🔐 💗 大家…

Gemini與GPT-4的巔峰對決:AI界的雙壁之戰

隨著人工智能技術的飛速發展,AI領域的競爭越來越激烈。在這個充滿挑戰與機遇的時代,兩個備受矚目的AI巨頭——Gemini Pro和GPT-4,成為了人們關注的焦點。這兩者都以其強大的功能和卓越的性能,引領著AI領域的發展潮流。本文將詳細介…

MyBatisX插件

MyBatisX插件 MyBatis-Plus為我們提供了強大的mapper和service模板,能夠大大的提高開發效率。 但是在真正開發過程中,MyBatis-Plus并不能為我們解決所有問題,例如一些復雜的SQL,多表聯查,我們就需要自己去編寫代碼和SQ…

connection error;reply-code=503;unknown exchange type ‘x-delayed-message‘

錯誤原因 這個錯誤表明你的 RabbitMQ 服務器不認識交換機類型 “x-delayed-message”,這通常是因為你的 RabbitMQ 服務器沒有啟用 rabbitmq_delayed_message_exchange 插件,或者插件版本與你的 RabbitMQ 服務器不兼容。 解決方法 啟用 RabbitMQ 延遲隊…

JAVA安全之Spring參數綁定漏洞CVE-2022-22965

前言 在介紹這個漏洞前,介紹下在spring下的參數綁定 在Spring框架中,參數綁定是一種常見的操作,用于將HTTP請求的參數值綁定到Controller方法的參數上。下面是一些示例,展示了如何在Spring中進行參數綁定: 示例1&am…

2024年C語言基礎知識入門來了,一文搞定C語言基礎知識!

一、C語言基礎知識入門 c語言基礎知識入門一經出現就以其功能豐富、表達能力強、靈活方便、應用面廣等特點迅速在全世界普及和推廣。C語言不但執行效率高而且可移植性好,可以用來開發應用軟件、驅動、操作系統等,2024年C語言基礎知識入門大全。C語言基礎…

Spring boot 使用Redis 消息發布訂閱

Spring boot 使用Redis 消息發布訂閱 文章目錄 Spring boot 使用Redis 消息發布訂閱Redis 消息發布訂閱Redis 發布訂閱 命令 Spring boot 實現消息發布訂閱發布消息消息監聽主題訂閱 Spring boot 監聽 Key 過期事件消息監聽主題訂閱 最近在做請求風控的時候,在網上搜…

postgreSql邏輯復制常用語句匯總和說明

簡單說明 postgreSql邏輯復制的原理這里不再贅述,度娘一下即可。這里只是對常用的語句做一些匯總和說明,以便日后查找時方便。 邏輯復制的概念 邏輯復制整體上采用的是一個發布訂閱的模型,訂閱者可以訂閱一個或者多個發布者, 發…

全套的外貿出口業務流程,趕緊收藏起來吧

很多做外貿的小伙伴入行遇到的第一個問題就是對外貿業務流程的不熟悉,今天小易給大家整理了一份外貿業務全流程,從開發客戶到售后服務一整套流程,一起來看看吧! 目前做外貿開發客戶的渠道一般有以下幾種: 1、自建站、外…

如何在 Windows 中恢復已刪除的 Excel 文件?– 8 個有效方法!

如何恢復已刪除的Excel文件?如果您不小心刪除了 Excel 文件或該文件已損壞,您無需擔心會丟失寶貴的數據。MiniTool 分區向導的這篇文章提供了 8 種有效的方法來幫助您恢復它們。 Microsoft Excel 是 Microsoft 為 Windows、macOS、Android、iOS 和 iPad…