当前位置: 首页 > article >正文

WHAT - 缓存命中 Cache Hit 和缓存未命中 Cache Miss

文章目录一、什么是缓存命中二、前端开发要知道哪些缓存机制以及命中条件1. 浏览器缓存主要针对静态资源常见的缓存位置关键 HTTP 头字段决定命中与否2. 前端应用层缓存例如数据请求三、前端开发者需要掌握哪些实践浏览器缓存策略实战建议数据缓存建议四、如何判断资源是否命中缓存五、缓存未命中总结作为前端开发者理解缓存命中Cache Hit非常重要尤其在你处理性能优化、资源加载、用户体验提升、离线支持等方面。一、什么是缓存命中缓存命中Cache Hit指当你请求某个资源比如图片、JS 文件、API 响应等时浏览器或其他中间层发现缓存中已有该资源于是直接返回缓存结果而不需要再去网络请求。这样做有两个好处提升加载速度从缓存读取远比从网络拉取快得多。减少服务器压力命中缓存后不发起请求减轻后端负担。二、前端开发要知道哪些缓存机制以及命中条件前端缓存机制主要分为两大类浏览器缓存静态资源和应用层缓存数据、状态。1. 浏览器缓存主要针对静态资源常见的缓存位置内存缓存Memory Cache短期缓存刷新页面即失效。磁盘缓存Disk Cache持久性更强关闭浏览器后依然有效。Service Worker 缓存你控制的离线缓存可以精细化管理。Push CacheHTTP/2很短暂针对同一次会话的缓存。关键 HTTP 头字段决定命中与否字段作用示例Cache-Control控制是否缓存、缓存时长max-age3600,no-cacheETag内容标识符用于比较是否更新ETag: abc123Last-Modified上次修改时间Last-Modified: Wed, 01 May 2024 12:00:00 GMTExpires绝对过期时间已被 Cache-Control 替代Expires: Tue, 21 May 2025 08:00:00 GMT命中机制简化流程浏览器请求资源。如果缓存未过期如max-age生效 →强缓存命中直接使用缓存。如果缓存过期 → 浏览器发送带上If-None-Match对比ETag或If-Modified-Since对比修改时间。若内容没变服务器返回304 Not Modified→协商缓存命中。否则重新返回新资源。2. 前端应用层缓存例如数据请求用于缓存 API 请求或状态数据例如localStorage/sessionStorage持久化存储。IndexedDB复杂结构、本地数据库。前端框架内缓存如 React Query、SWR、Apollo Client 等。例如在 SWR 中数据缓存命中机制基于key-value和revalidation 策略const{data}useSWR(/api/user,fetcher)再次访问相同 keyURL→ 命中缓存。根据配置决定是否 revalidate重新请求。三、前端开发者需要掌握哪些实践浏览器缓存策略实战建议设置合理的 Cache-ControlJS/CSS 设置长时间缓存Cache-Control: public, max-age31536000, immutableHTML 页面设置短时间缓存 协商缓存no-cache使用文件哈希名作为缓存破坏手段Cache Busting比如main.3f3c1f.js文件变了名字也变了浏览器会重新加载。服务端正确返回 ETag/Last-Modified保证协商缓存生效减少带宽开销。数据缓存建议用 SWR、React Query 等库管理 API 缓存。配合缓存时间和 revalidation 策略如stale-while-revalidate。结合 localStorage / IndexedDB 实现离线缓存支持。四、如何判断资源是否命中缓存打开浏览器开发者工具DevTools刷新页面Network 面板查看请求看Status和Size列200 (from disk cache)磁盘缓存命中200 (from memory cache)内存缓存命中304 Not Modified协商缓存命中五、缓存未命中缓存未命中Cache Miss是指在系统尝试从缓存中读取数据时未找到所需数据因此需要从更慢的存储介质比如内存或硬盘中加载数据的情况。这会导致访问延迟增加是性能优化中需要重点关注的问题。缓存未命中通常分为以下几种类型强制未命中Compulsory Miss也叫冷启动未命中是指某个数据首次被访问时由于之前从未加载过所以缓存中自然没有必须从原始数据源加载。容量未命中Capacity Miss缓存容量不足无法容纳所有活跃数据因此部分数据被替换后续访问这些数据时就会发生未命中。冲突未命中Conflict Miss在组相联缓存或直接映射缓存中不同的数据映射到了同一个缓存位置导致彼此竞争位置并被替换从而造成未命中。举个例子假设你打开了一个网页网页上的某张图片之前没有加载过——这时候浏览器会从服务器下载图片并缓存起来。这就是强制未命中。下次你再次访问该页面如果缓存被清除或图片被替换掉了再加载时就可能是容量未命中或冲突未命中。总结缓存命中是前端性能优化的核心手段之一理解浏览器缓存机制、合理配置 HTTP 头信息、结合应用层缓存工具可以极大提升用户体验。

相关文章:

WHAT - 缓存命中 Cache Hit 和缓存未命中 Cache Miss

文章目录一、什么是缓存命中二、前端开发要知道哪些缓存机制(以及命中条件)1. 浏览器缓存(主要针对静态资源)常见的缓存位置关键 HTTP 头字段(决定命中与否)2. 前端应用层缓存(例如数据请求&…...

一文搞定常见网络安全技术:网络攻击与核心防范手段全景解析(建议收藏)

伴随着互联网的发展,它已经成为我们生活中不可或缺的存在,无论是个人还是企业,都离不开互联网。正因为互联网得到了重视,网络安全问题也随之加剧,给我们的信息安全造成严重威胁,而想要有效规避这些风险&…...

Linux网络安全从入门到精通:基础命令、安全配置与实战案例(保姆级教程)

Linux网络安全一直是IT行业中备受关注的话题,而红帽作为Linux操作系统的知名发行版,在网络安全领域也扮演着重要的角色。红帽公司一直致力于为用户提供安全可靠的Linux解决方案,以帮助用户建立强大的网络安全防护体系。 首先,红帽…...

cobbler + pxe+dhcp+tftp+httpd+kickstart无人值守装系统

一、cobbler简介 cobbler是基于Python2开发并整合pxe+kickstart技术的二次封装工具,简化了安装部署流程,增加了对多发行版的支持,并且有独立的web管理页面,极大方便了运维初级人员的学习和使用。另外cobbler还提供了API,方便二次开发。 该文章主要介绍使用cobbler自动装机…...

网络安全岗位全解析:从入门到优秀工程师的进阶路线图(建议收藏)

网络安全是什么? 首先说一下什么是网络安全? 网络安全工程师工作内容具体有哪些? 网络安全是确保网络系统的硬件、软件及其系统中的数据受到保护,不因偶然的或者恶意的原因而受到破坏、更改、泄露,系统连续可靠正常地…...

如何快速掌握Embark框架:从代码规范到贡献流程的完整指南

如何快速掌握Embark框架:从代码规范到贡献流程的完整指南 【免费下载链接】embark 项目地址: https://gitcode.com/gh_mirrors/emb/embark Embark是一个功能强大的区块链开发框架,它简化了以太坊DApp的开发流程,提供了从智能合约编译…...

RLHF在多模态领域的应用:MM-RLHF框架与视觉语言模型对齐技术

RLHF在多模态领域的应用:MM-RLHF框架与视觉语言模型对齐技术 【免费下载链接】awesome-RLHF A curated list of reinforcement learning with human feedback resources (continually updated) 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-RLHF 多…...

从入门到精通:LedisDB命令完全指南,解锁高性能数据存储操作

从入门到精通:LedisDB命令完全指南,解锁高性能数据存储操作 【免费下载链接】ledisdb 项目地址: https://gitcode.com/gh_mirrors/led/ledisdb LedisDB是一款兼容Redis协议的高性能数据存储系统,支持多种数据结构和高级功能。本文将全…...

ExLlamaV2动态批处理生成器深度解析

ExLlamaV2动态批处理生成器深度解析 【免费下载链接】exllamav2 A fast inference library for running LLMs locally on modern consumer-class GPUs 项目地址: https://gitcode.com/gh_mirrors/ex/exllamav2 引言:大模型推理的性能瓶颈与解决方案 在大语言…...

每日八股文6.12

每日八股-6.12计算机网络1.当我们在浏览器中输入一个 URL 并按下回车后,到页面最终显示出来,这中间都发生了哪些关键步骤?2.请简述一下 JWT(JSON Web Tokens)的原理和校验机制3.DNS 是如何进行域名解析的?它…...

SecretVault强网杯2025 Web题解:从JWT绕过到HTTP头注入的实战剖析

1. 初探SecretVault:一个看似简单的Web应用 最近在复盘强网杯2025的一道Web题目,叫SecretVault。这道题挺有意思的,它表面上是一个密码保险箱应用,你可以登录、注册,然后把你的各种账号密码加密存进去。题目环境一打开…...

用UE5 Multi-User Editing实现远程团队协作:公网部署+会话管理全流程解析

用UE5 Multi-User Editing实现远程团队协作:公网部署会话管理全流程解析 最近和几个分布在不同城市的朋友一起捣鼓一个UE5的独立项目,最大的痛点就是资产和场景的同步。今天传个地图,明天发个蓝图,版本很快就乱成一锅粥。直到我们…...

Fabric、FISCO BCOS与以太坊:三大区块链平台的技术架构与应用场景解析

1. 开篇:为什么需要了解不同的区块链平台? 如果你刚开始接触区块链,可能会觉得眼花缭乱。以太坊、Fabric、FISCO BCOS……这些名字听起来都很厉害,但它们到底有什么区别?我该用哪个?这就像你要盖房子&#…...

幻兽帕鲁服务器搭建全攻略:从SteamCMD到端口转发一步到位

幻兽帕鲁私服搭建实战:从零构建稳定可联机的专属世界 最近身边不少朋友都沉迷于《幻兽帕鲁》这款游戏,但官服有时难免会遇到延迟、排队或者想和固定小圈子朋友一起玩的限制。于是,自己动手搭建一个专属服务器的念头就冒了出来。这听起来像是资…...

Charles实战:手把手教你模拟复杂网络环境下的弱网测试

1. 为什么你的App一到地铁里就卡?聊聊弱网测试那点事 不知道你有没有遇到过这种情况:早上通勤,在地铁里刷着新闻App,图片半天加载不出来,刷个短视频一直转圈圈,甚至点个外卖提交订单时直接卡死闪退。你可能…...

从柳树皮到实验室:水杨酸合成技术演进与化妆品原料安全标准解析

从柳树皮到实验室:水杨酸合成技术演进与化妆品原料安全标准解析 当我们谈论护肤品中的“刷酸”时,水杨酸几乎是一个绕不开的名字。它被成分党们奉为对抗黑头、闭口和痘痘的利器,但很少有人去深究,涂抹在脸上的那一滴精华或乳霜里&…...

[QCM6125][Android13] 关闭dm-verity后OTA升级兼容性校验的应对策略

1. 从一次失败的OTA升级说起:关闭dm-verity后的连锁反应 最近在折腾一块基于高通QCM6125平台的开发板,系统是Android 13。为了让设备获得更高的灵活性,比如能直接remount /分区进行一些调试和修改,我按照老习惯把dm-verity给关掉了…...

差分进化算法:从理论到实战的全局优化利器

1. 为什么说差分进化是你的下一个“秘密武器”? 大家好,我是老张,在AI和算法优化这个行当里摸爬滚打了十几年。今天想跟你聊聊一个我特别钟爱,并且在实际项目中屡建奇功的算法——差分进化。你可能听说过遗传算法、粒子群优化&…...

GIS开发必知:EPSG 4326和3857坐标系到底怎么选?附OpenLayers实战代码

GIS开发坐标系抉择:从原理到实战,深度解析4326与3857 最近在帮团队重构一个老旧的WebGIS项目时,我又一次被坐标系问题绊住了。数据源是标准的WGS84经纬度,但前端地图库默认渲染的却是Web墨卡托投影。页面上的几何图形拉伸变形&…...

基于eNSP的IPv4/IPv6双栈网络高可用与安全融合设计【企业园区网实战】

1. 项目背景与设计目标:为什么需要双栈高可用园区网? 大家好,我是老陈,一个在园区网里摸爬滚打了十多年的老网工。这些年,我亲眼看着网络从纯IPv4,到各种过渡技术,再到如今IPv6的全面铺开。很多…...

麒麟勒索软件攻击朝日集团事件解析:如何保护企业免受RaaS平台威胁

麒麟勒索软件攻击朝日集团事件解析:如何保护企业免受RaaS平台威胁 最近,一家全球知名的制造业巨头遭遇的网络攻击事件,在安全圈内外都引发了不小的震动。生产线停摆、供应链中断、敏感数据泄露,这些看似只存在于新闻中的场景&…...

智能工厂四大系统协同实战:ERP/PLM/MES/WMS数据流与接口设计全解析

1. 从“各自为政”到“协同作战”:为什么你的系统总在“打架”? 我干了这么多年智能工厂的规划和落地,发现一个特别普遍的现象:很多老板花大价钱上了ERP、PLM、MES、WMS,结果呢?数据还是对不上,…...

MTK SensorHub:从驱动注册到数据上报的完整流程剖析

1. 初识MTK SensorHub:手机里的“传感器大管家” 大家好,我是老张,在手机芯片和传感器这块摸爬滚打了十几年。今天咱们不聊那些虚头巴脑的概念,就掰开揉碎了讲讲MTK平台上一个非常核心但又有点神秘的东西——SensorHub。你可以把它…...

利用Docker搭建青龙面板:一站式京东自动签到与脚本管理指南

1. 为什么你需要青龙面板?从手动签到到自动化管理的蜕变 不知道你有没有这样的经历:每天醒来第一件事,不是刷牙洗脸,而是摸出手机,打开好几个购物APP,挨个点开签到页面,只为领那几毛钱的红包或者…...

华为昇腾NPU实战:Mistral-7B-v0.3模型部署避坑指南(附完整代码)

华为昇腾NPU实战:Mistral-7B-v0.3模型部署避坑指南(附完整代码) 最近在国产AI硬件上折腾大模型的朋友越来越多了,尤其是像Mistral-7B这类性能与效率兼顾的开源模型,大家都想看看它在昇腾NPU上的表现到底如何。我花了差…...

Ubuntu下Qt6与fcitx5中文输入法的深度集成指南

1. 为什么你的Qt6程序在Ubuntu上打不出中文? 这个问题我猜不少在Linux上用Qt6做开发的朋友都遇到过。你兴致勃勃地写了个带文本输入框的界面,运行起来,切到中文输入法,噼里啪啦一顿敲,结果屏幕上要么纹丝不动&#xff…...

MEMS惯性导航单元标定与测试的实践指南:从理论到代码实现

1. 为什么你的MEMS惯导不准?从“体检”开始说起 大家好,我是老张,在机器人导航这行摸爬滚打了十几年,用过、拆过、也标定过无数个MEMS惯性导航单元。我发现很多刚入行的工程师,包括一些做无人机、自动驾驶小车或者手持…...

从靶场到实战:Xray漏洞扫描工具的配置与高效扫描指南

1. 从靶场到实战:为什么你的Xray需要“毕业设计” 很多朋友第一次接触Xray,可能和我当初一样,都是从在线靶场开始的。比如经典的 testphp.vulnweb.com,一条命令 xray webscan --url http://testphp.vulnweb.com 跑下去&#xff0c…...

嵌入式开发实战:StateFlow在MATLAB中的高效应用

1. 从零开始:为什么嵌入式开发需要StateFlow? 如果你做过嵌入式开发,肯定遇到过这样的场景:一个设备,比如智能电饭煲,它有“待机”、“加热”、“保温”、“故障”这几个状态。写代码控制它的时候&#xff…...

深入解析AOMDV协议:多路径路由在Ad hoc网络中的实现与优化

1. 从单行道到立交桥:为什么Ad hoc网络需要AOMDV? 想象一下,你正在一个大型音乐节现场,手机信号时断时续,你和朋友走散了,想发条消息都发不出去。这时候,如果你们所有人的手机能自动“手拉手”组…...