缓存类型以及读写策略

news2024/9/20 9:40:58

缓存(Cache)是一种高效的数据存储技术,旨在提高数据访问速度。

它将频繁访问或最近使用的数据临时存储在更快速但较小的存储介质(如内存)中,以减少从较慢的存储设备(如硬盘或远程服务器)读取数据的次数。以下是一些关于缓存的关键点:

缓存的分类

在系统开发中,缓存可以根据不同的维度进行分类。以下是常见的缓存分类:

根据存储介质分类

  1. 内存缓存(In-Memory Cache)

    • 示例:Redis、Memcached
    • 特点:速度快,但容量有限,适用于需要快速访问的数据。
  2. 磁盘缓存(Disk Cache)

    • 示例:本地文件系统缓存
    • 特点:速度较慢,但容量较大,适用于大数据量的缓存需求。

根据缓存层级分类

  1. 一级缓存(L1 Cache)

    • 位置:通常在CPU内部,靠近处理器核心。
    • 特点:速度最快,容量最小,用于存储最频繁访问的数据和指令。
  2. 二级缓存(L2 Cache)

    • 位置:在CPU内部或外部,介于L1缓存和内存之间。
    • 特点:速度和容量介于L1缓存和内存之间。
  3. 三级缓存(L3 Cache)

    • 位置:通常在多个CPU核心之间共享。
    • 特点:速度较慢但容量较大,适用于减少不同核心之间的数据访问延迟。

根据缓存作用范围分类

  1. 本地缓存(Local Cache)

    • 特点:缓存数据存储在本地机器上,适用于单机系统。
  2. 分布式缓存(Distributed Cache)

    • 示例:Redis Cluster、Amazon DynamoDB
    • 特点:缓存数据分布在多个机器上,适用于分布式系统,提高系统的可扩展性和容错能力。

根据数据更新策略分类

  1. 写通过缓存(Write-Through Cache)

    • 特点:数据在写入缓存的同时也写入后端存储,确保数据一致性。
  2. 写回缓存(Write-Back Cache)

    • 特点:数据首先写入缓存,只有在缓存中的数据被替换或过期时才写入后端存储,能提高写入性能,但可能导致数据一致性问题。

根据缓存淘汰策略分类

  1. LRU(Least Recently Used)

    • 特点:移除最久未使用的数据。
  2. LFU(Least Frequently Used)

    • 特点:移除访问频率最低的数据。
  3. FIFO(First In, First Out)

    • 特点:按数据进入缓存的顺序进行移除,先进入的先移除。

根据应用场景分类

  1. 浏览器缓存(Browser Cache)

    • 特点:存储网页资源(如HTML、CSS、JavaScript等),减少页面加载时间。
  2. 数据库缓存(Database Cache)

    • 示例:MySQL Query Cache、Oracle Result Cache
    • 特点:缓存数据库查询结果,提高查询性能。
  3. 应用缓存(Application Cache)

    • 示例:Spring Cache、Ehcache
    • 特点:应用程序内部实现的缓存机制,减少对后端服务的调用。

其他分类

  1. 会话缓存(Session Cache)

    • 特点:用于存储用户会话数据,如登录状态、购物车等。
  2. 对象缓存(Object Cache)

    • 特点:缓存复杂的对象或数据结构,提高对象的创建和访问速度。

常见缓存类型

在日常开发中,确实静态缓存、分布式缓存和热点本地缓存是最常见的三种缓存类型。 

常见缓存分类

静态缓存

定义:静态缓存通常用于缓存静态内容,例如HTML页面、CSS文件、JavaScript文件、图像等。它可以显著减少服务器负载和响应时间。

应用场景

  • 网页缓存:浏览器缓存网页资源,减少对服务器的请求,提高页面加载速度。
  • 内容分发网络(CDN):CDN缓存网站的静态资源,将内容分发到全球各地的边缘节点,提高用户访问速度。

实现方式

  • HTTP缓存头:使用Cache-Control、ETag、Last-Modified等HTTP头控制缓存行为。
  • 反向代理:例如Nginx、Varnish等反向代理服务器,用于缓存静态资源并响应请求。

分布式缓存

定义:分布式缓存是将缓存数据分布在多个服务器节点上,以提高系统的可扩展性和容错能力。它适用于分布式系统或高并发场景。

应用场景

  • 大规模Web应用:如社交网络、电子商务网站,需要处理大量用户请求。
  • 分布式系统:在微服务架构中,各个服务之间共享和缓存数据。

实现方式

  • Redis:高性能的分布式内存数据库,支持数据持久化和高可用集群。
  • Memcached:轻量级的分布式内存缓存系统,适用于缓存简单数据结构。

热点本地缓存

定义:热点本地缓存是指将频繁访问的数据缓存到本地内存中,以提高访问速度和减少对远程服务的依赖。通常用于单机系统或单个服务实例内。

应用场景

  • 应用程序内部缓存:如Java应用中的Ehcache、Guava Cache,用于缓存计算结果或数据库查询结果。
  • 临时数据缓存:如用户会话数据、短期有效的数据等。

实现方式

  • Ehcache:Java中常用的开源缓存框架,支持多种缓存策略和持久化。
  • Guava Cache:Google的Guava库提供的轻量级缓存实现,适用于简单缓存需求。

缓存的读写策略

选择缓存的读写策略是缓存设计中的关键步骤,它直接影响系统的性能、数据一致性和可用性。以下是几种常见的缓存读写策略及其适用场景:

1.旁路 Cache Aside

旁路策略

读旁路(Cache Read-Aside)

定义:应用程序首先从缓存读取数据,如果未命中,则从后端数据源读取,并将数据手动写入缓存。

优点

  • 简单易实现,适用于现有系统的改造。
  • 可以灵活地控制缓存更新策略。

缺点

  • 需要在应用程序中添加缓存逻辑,增加了代码复杂度。
  • 可能导致缓存与后端数据源的一致性问题。

适用场景

  • 读写操作相对均衡的场景。
  • 应用程序可以接受一定程度的数据不一致。
写旁路(Cache Write-Aside)

定义:应用程序直接将数据写入后端数据源,并删除缓存。

优点

  • 简单易实现,适用于现有系统的改造。
  • 保证后端数据源的权威性。

缺点

  • 读取操作需要额外处理缓存未命中的情况。

适用场景

  • 读操作频繁,写操作较少的场景。
  • 对数据一致性有较高要求。

2.读写穿透

读写穿透

读穿透(Cache Read-Through)

定义:当缓存未命中时,缓存系统自动从后端数据源读取数据,并将其存储在缓存中。

优点

  • 简化了应用程序的逻辑,应用只需与缓存交互。
  • 确保缓存与后端数据源的一致性。

缺点

  • 需要额外的读操作,增加了延迟。
  • 复杂性增加,可能需要定制缓存和数据源的集成。

适用场景

  • 读取频繁、写入较少的场景。
  • 需要保证数据的一致性。
写穿透(Cache Write-Through)

定义:当数据写入缓存时,缓存系统同步将数据写入后端数据源。

优点

  • 保证数据的一致性。
  • 简化应用程序的逻辑,应用只需与缓存交互。

缺点

  • 写操作需要同步到后端数据源,增加了写操作的延迟。
  • 缓存系统和后端数据源之间的同步可能会影响性能。

适用场景

  • 写操作频率较低,读取频繁的场景。
  • 需要保证数据一致性的重要数据。

3. 写回(Cache Write-Back)

写返回

定义:数据首先写入缓存,并在一定时间或条件下异步写入后端数据源。

优点

  • 提高写操作的性能,减少写入延迟。
  • 缓解后端数据源的写压力。

缺点

  • 复杂性增加,需处理缓存和后端数据源的一致性问题。
  • 可能导致数据丢失或不一致,特别是在系统崩溃或缓存失效时。

适用场景

  • 写操作频繁,需要高性能的写入场景。
  • 可以容忍一定程度的数据不一致或延迟。

如何选择合适的策略?

  1. 读写频率:分析读写操作的频率,如果读多写少,读穿透和读旁路较为适用;如果写多读少,写穿透和写回较为适用。
  2. 数据一致性要求:如果数据一致性要求高,优先考虑读穿透和写穿透策略;如果可以接受一定的一致性延迟,可以选择写回策略。
  3. 性能要求:如果对写入性能要求高,写回策略可以提高写操作的性能;如果对读取性能要求高,读穿透和读旁路可以提高读取速度。
  4. 复杂性和实现成本:考虑实现的复杂性和维护成本,选择合适的策略平衡性能和开发复杂性。

关于ArchManual

https://archmanual.com

https://github.com/yingqiangh/ArchManual

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2113246.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

聊一聊大型网站稳定性建设思路

目录 架构阶段的稳定性建设项目 编码阶段的稳定性建设 测试阶段的稳定性建设 发布阶段的稳定性建设 运行阶段的稳定性建设项目 故障发生时的稳定性建设 网站稳定性的建设是一项综合的系统工程,就像人的健康一样,如果平时不注意健康饮食、不注意锻炼…

浙大数据结构:02-线性结构4 Pop Sequence

这道题我们采用数组来模拟堆栈和队列。 简单说一下大致思路,我们用栈来存1234.....,队列来存输入的一组数据,栈与队列进行匹配,相同就pop 机翻 1、条件准备 stk是栈,que是队列。 tt指向的是栈中下标,fr…

C++入门(05-2)从命令行执行C++编译器_GCC

文章目录 GCC编译器1. 下载MinGW-w64,安装(不推荐)2. 使用MSYS2安装MinGW-w64(推荐)2.1 安装MSYS22.2 初始化和更新2.3 安装MinGW-w64编译器2.3 在MSYS2 Shell中导航到代码目录2.4 使用 g 编译2.5 运行可执行文件 GCC编…

【Qt】qt发布Release版本,打包.exe可执行文件

前言:Qt编译的可执行程序,如果直接运行,会出现0xc000007b报错,或者“由于占不到Qt5Network.dll,无法继续执行代码。重新安装程序可能会解决此问题”的报错,因为缺少相关的依赖包和动态库。 1、第一步:找到…

仕考网:大三能考公务员吗?

本科生在大三阶段不具备报考资格,因为尚未完成学业并不是应届生。专科生在大三时则属于应届生,有资格参加公务员考试。 公务员报考条件包括: 1.国籍; 2.年龄于18至35周岁之间,对于当年毕业的硕士或博士研究生,年龄限…

Python: #!/usr/bin/python3 #!/usr/bin/env python3

只能放在第一行,第二行就没有效果了。 1. 路径不同 #!/usr/bin/python3&& #!/usr/bin/env python3写在脚本语言第一行的目的是 想要以什么可执行程序去运行这个文件中的代码。 #!/usr/bin/python3是告诉操作系统执行这个脚本的时候,调用/usr/bin…

Linux之ebpf(3)uprobe与ebpf

Linux之ebpf(3)uprobe简要使用 Author: Once Day Date: 2024年9月5日 一位热衷于Linux学习和开发的菜鸟,试图谱写一场冒险之旅,也许终点只是一场白日梦… 漫漫长路,有人对你微笑过嘛… 全系列文章可参考专栏: Linux基础知识_Once-Day的博客…

心脑血管科张景龙医生:冠状动脉狭窄的症状与检查方法

冠状动脉狭窄作为一种常见的心血管疾病,其症状的出现往往与心肌供血不足密切相关。了解这些症状以及如何进行准确的检查,对于及早发现、诊断和治疗冠状动脉狭窄至关重要。本文将详细介绍冠状动脉狭窄的常见症状及检查方法。 冠状动脉狭窄的常见症状 1、…

电路笔记 控制(PID):Proportional–integral–derivative controller 比例-积分-微分控制器与仿真

PID控制(Proportional-Integral-Derivative Control)是一种常用的反馈控制算法,广泛应用于自动控制系统中。PID控制器通过对比例、积分和微分三项的计算,生成控制输出来调节系统的行为,以使其达到期望的目标值。 PID控…

利用人类反馈优化文本摘要质量

人工智能咨询培训老师叶梓 转载标明出处 精准评估和提升模型生成文本的质量,尤其是自动文摘的质量,成为了一个日益突出的挑战。传统的评估方法,如ROUGE指标,虽然在一定程度上能够衡量摘要的相关性,但往往无法全面反映…

Java算法:最大间距

前言 在处理数据密集型应用时,提高查询性能显得尤为关键。 解决最大间隔问题——即确定一组数值中最宽的相邻元素距离——是此类任务中的一大挑战。 该问题不仅在算法竞赛中常见,也是软件工程师面试的一个焦点,解决方法多样,包…

【B题第三套完整论文已出】2024数模国赛B题第三套完整论文+可运行代码参考(无偿分享)

基于多阶段优化的电子产品质量控制与成本管理研究 摘要 随着现代制造业和智能化生产的发展,质量控制和生产优化问题成为工业管理中的重要研究课题。本文针对电子产品生产过程中质量控制和成本优化中的问题,基于系统优化和决策分析思想,通过…

【C++ Primer Plus习题】12.1

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream> #include "Cow.h" u…

空气能热泵热水器

空气能热泵热水器压缩机把低温低压气态冷媒转换成高压高温气态&#xff0c;压缩机压缩功能转化的热量为q1&#xff0c;高温高压的气态冷媒与水进行热交换&#xff0c;高压的冷媒在常温下被冷却、冷凝为液态。这过程中&#xff0c;冷媒放出热量用来加热水&#xff0c;使水升温变…

机器学习数学公式推导之降维

文章目录 降维线性降维-主成分分析 PCA损失函数SVD 与 PCoASVD 的基本形式SVD 的计算p-PCA 小结 P22 (系列五) 降维1-背景 本文参考 B站UP: shuhuai008 &#x1f339;&#x1f339; 降维 我们知道&#xff0c;解决过拟合的问题除了正则化和添加数据之外&#xff0c;降维就是最…

数据链路层与ARP协议

一.认识识以太网 "以太网" 不是一种具体的网络, 而是一种技术标准; 既包含了数据链路层的内 容, 也包含了一些物理层的内容. 例如: 规定了网络拓扑结构, 访问控制方式, 传输速率等; 以太网中的网线必须使用双绞线; 传输速率有 10M, 100M, 1000M 等; 以太网是当前应用…

【最新华为OD机试E卷-支持在线评测】机器人活动区域(100分)多语言题解-(Python/C/JavaScript/Java/Cpp)

🍭 大家好这里是春秋招笔试突围 ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-E/D卷的三语言AC题解 💻 ACM金牌🏅️团队| 多次AK大厂笔试 | 编程一对一辅导 👏 感谢大家的订阅➕ 和 喜欢💗 🍿 最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,…

2024年【金属非金属矿山(露天矿山)安全管理人员】考试题及金属非金属矿山(露天矿山)安全管理人员最新解析

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 金属非金属矿山&#xff08;露天矿山&#xff09;安全管理人员考试题参考答案及金属非金属矿山&#xff08;露天矿山&#xff09;安全管理人员考试试题解析是安全生产模拟考试一点通题库老师及金属非金属矿山&#xf…

Java魔板游戏软件(含代码)

✅作者简介&#xff1a;2022年博客新星 第八。热爱国学的Java后端开发者&#xff0c;修心和技术同步精进。 &#x1f34e;个人主页&#xff1a;Java Fans的博客 &#x1f34a;个人信条&#xff1a;不迁怒&#xff0c;不贰过。小知识&#xff0c;大智慧。 &#x1f49e;当前专栏…

【第0007页 · 数组】数组中重复的数据(如何实现数组的原地修改)

【前言】本文以及之后的一些题解都会陆续整理到目录中&#xff0c;若想了解全部题解整理&#xff0c;请看这里&#xff1a; 第0007页 数组中重复的数据 今天&#xff0c;我们来看一个在实际工作中运用不多&#xff0c;但是对于一些算法题还是有必要的奇技淫巧——数组的原地修…