一次js请求一般情况下有哪些地方会有缓存处理

news2024/12/22 8:49:32

目录

前言

1. 浏览器缓存

1.1 强缓存

用法

代码

理解

1.2 协商缓存

用法

代码

理解

2. 服务端缓存

2.1 反向代理缓存

用法

代码

理解

2.2 应用层缓存

用法

代码

理解

3. CDN缓存

3.1 用法

3.2 理解

4. DNS缓存

4.1 用法

4.2 理解

5. AJAX请求缓存

5.1 用法

5.2 代码

5.3 理解

总结


前言

在现代的Web开发中,性能优化一直是一个重要的话题。缓存作为性能优化的重要手段之一,其作用不可小觑。它能够减少网络传输的数据量,降低服务器的负载,提高页面加载的速度,从而提升用户体验。在一次JavaScript请求的过程中,缓存可能发生在多个地方,包括浏览器缓存、CDN缓存、服务器缓存等。本文将深入探讨这些缓存机制的工作原理、使用方法和相关的代码实现,帮助开发者更好地理解和利用缓存来优化网站性能。

1. 浏览器缓存

1.1 强缓存

用法

强缓存是通过HTTP响应头中的Cache-ControlExpires字段来控制的。Cache-Control可以设置资源的最大生存时间(max-age),而Expires则是一个绝对时间,表示资源的过期时间。

代码

// 设置Cache-Control,资源将被缓存10秒
res.setHeader('Cache-Control', 'max-age=10');

理解

强缓存的优点是能够直接从浏览器缓存中加载资源,不需要发送任何请求到服务器,从而极大地提高了加载速度。但是,一旦资源被缓存,就无法实时更新,直到缓存过期。

1.2 协商缓存

用法

当强缓存失效后,浏览器会发送一个HTTP请求到服务器,带有If-Modified-SinceIf-None-Match字段,服务器根据这些字段来决定是否返回304状态码,告诉浏览器可以使用本地缓存。

代码

// 设置Last-Modified,表示资源的最后修改时间
res.setHeader('Last-Modified', 'Tue, 15 Jun 2021 12:45:26 GMT');
// 设置ETag,表示资源的唯一标识
res.setHeader('ETag', '"abc123"');

理解

协商缓存虽然需要发送请求到服务器,但是当资源未修改时,只需要传输HTTP头部,不需要传输资源内容,仍然能够节省大量的带宽和提高加载速度。

2. 服务端缓存

2.1 反向代理缓存

用法

在Nginx等反向代理服务器中配置缓存规则,根据文件类型、URL等条件来决定哪些资源需要被缓存。

代码

location ~* \.(jpg|jpeg|png|gif|ico|css|js)$ {
    expires 30d;
    add_header Cache-Control "public, no-transform";
}

理解

反向代理缓存能够减轻后端服务器的压力,提高资源加载的速度。但是需要合理配置缓存规则,避免缓存过时的资源。

2.2 应用层缓存

用法

使用Memcached或Redis等缓存数据库来存储经常访问的数据。

代码

const redis = require('redis');
const client = redis.createClient();

// 设置缓存
client.set('key', 'value', 'EX', 10); // 缓存10秒

// 获取缓存
client.get('key', function(err, reply) {
    console.log(reply); // 输出:value
});

理解

应用层缓存能够减少数据库查询的次数,提高数据访问的速度。但是需要合理设计缓存策略,避免缓存过多无用的数据。

3. CDN缓存

3.1 用法

将静态资源部署到CDN上,CDN节点会根据配置的规则对资源进行缓存。

3.2 理解

CDN缓存能够将资源缓存到离用户更近的地方,减少资源加载的延迟,提高加载速度。但是需要合理选择CDN服务商,配置合适的缓存规则。

4. DNS缓存

4.1 用法

DNS解析的结果会被浏览器、操作系统等缓存一段时间。

4.2 理解

DNS缓存能够减少DNS解析的次数,提高域名解析的速度。但是当DNS记录更新时,可能会因为缓存导致解析结果不准确。

5. AJAX请求缓存

5.1 用法

在发送AJAX请求时,可以通过设置cache选项来控制是否允许浏览器缓存结果。

5.2 代码

$.ajax({
    url: 'example.json',
    cache: false, // 禁用缓存
    success: function(data) {
        console.log(data);
    }
});

5.3 理解

AJAX请求缓存能够减少相同请求的次数,提高数据加载的速度。但是需要根据实际情况来决定是否启用缓存。

总结

缓存是一种重要的性能优化手段,但是需要根据实际情况合理配置和使用。通过理解不同类型的缓存机制,开发者可以更好地利用缓存来提高网站性能,提升用户体验。

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

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

相关文章

大数据平台架构及规划

梳理了数据平台及未来规划,具体如下: 整体架构: 当前建设进展: 部署架构 部署架构2: Flink 实时计算平台架构 版本1: 版本2: 离线平台架构: 未来规划:

爱玛电动车:不止有时尚设计,更有领先的引擎动力科技

从外卖骑手的穿梭配送,到上班族的日常通勤;从年轻女孩的时尚出街,到为人父母的带娃出行。经过二十多年的高速发展和监管探索,电动两轮车已成为我国居民短途出行的重要民生交通工具和生产力工具,而消费者对电动车产品科技水准和质量的需求,也在不断提高。 未来,电动两轮车行业将…

记一次EasyExcel导出时将空格丢失的问题

EasyExcel的issues可以看到 需求:导出的数据以树形展示,如下: 导出结果: 原因: EasyExcel会默认去除掉空格,autoTrim熟悉默认为true,只需要设置为false即可。

学生用台灯应该选什么样的?分享好用的学生台灯

很多导致在那个不注重孩子学习的光线问题,导致孩子在不知不觉中视力下降。要知道,孩子在阅读书本、书写作业时,注意力都是高度集中的,如果孩子是在昏暗的光线下用眼,会造成瞳孔长时间散大,出现眼内液体循环…

【嵌入式】HC32F07X ADC采样及软件滤波

目录 一 背景说明 二 原理分析 三 电压采样 四 软件滤波 一 背景说明 使用小华(华大)的MCU HC32F07X实现四个通道的 0-5V 电压采样,并对采样结果进行滤波处理。 二 原理分析 【1】ADC原理说明: 单片机是数字芯片,…

【Ubuntu 终端终结者Ctrl shift e无法垂直分页解决办法】

Ubuntu 终端终结者Ctrl shift e无法垂直分页解决办法 错误原因解决办法 错误原因 这是因为ibus输入法有一个快捷键占用了这个终端终结者的快捷键 解决办法 打开命令行输入 ibus-setup进入到如下页面随后将其中的表情注释的快捷键删除即可

Java生成Jar包方法

1. 设置->项目结构 2. Artifacts->JAR->From modules… 3. 打开菜单栏 4. Build Artifacts… 5. Build或Rebuild (完)

《SpringBoot项目实战》第二篇—接口用户上下文的设计与实现

系列文章导航 第一篇—接口参数的一些弯弯绕绕 第二篇—接口用户上下文的设计与实现 第三篇—留下用户调用接口的痕迹 第四篇—接口的权限控制 第五篇—接口发生异常如何统一处理 本文参考项目源码地址:summo-springboot-interface-demo 前言 大家好!…

解决:谷歌浏览器访问http时,自动转https访问的问题

问题背景:某个系统网站,之前一直用https域名访问,现在改成http域名后,用http访问,谷歌浏览器会自动跳转到https。 解决方法: 在浏览器中输入网址:chrome://net-internals/#hsts -》 在“Delete…

Response Header中不暴露Server(IIS)版本、ASP.NET及相关版本等信息

ASP MVC开发的Web默认情况下会在请求的回应中暴露Server、X-AspNet-Version、X-AspNetMvc-Version、X-Powered-By等相关服务端信息,公开这些敏感信息会存在一定的安全风险。 X-SourceFiles标头用于被IIS / IIS Express中某些调试模块理解,它包含到磁盘上…

首个集成AI的国产操作系统带来了哪些惊喜

在2023年的统信UOS技术开放日暨deepin Meetup北京站上,统信UOS展示了其最新的AI技术和应用,标志着国产操作系统进入了一个全新的AI时代。作为国内领先的操作系统,统信UOS不仅为用户提供了更智能、更高效的服务,还为开发者打开了强…

颈肩肌筋膜炎做什么检查

颈肩肌筋膜炎症状 颈肩背部广泛疼痛酸胀沉重感、麻木感,僵硬、活动受限,可向后头部及上臂放散。疼痛呈持续性,可因感染、疲劳、受凉、受潮等因素而加重。查体见颈部肌紧张,压痛点常在棘突及棘突旁斜方肌、菱形肌等,压…

语雀宕机8小时,是否说明现在高可用架构很脆弱?

系列文章目录 高并发架构去重难?架构必备技能 - 布隆过滤器 当Dubbo遇到高并发:探究流量控制解决方案 主从选举机制,架构高可用性的不二选择 面试Dubbo ,却问我和Springcloud有什么区别? 消息队列选型——为什么选择R…

06 rpm和yum

rpm -ivh 软件包名 安装软件 yum仓库的配置和基本的命令使用 1 配置本地仓库文件 local.repo cd /etc/yum.repos.d/ vi local.repo 输入 [c6-local] nameCentOS-$releasever - local baseurlhttp://192.168.230.128/centos/6/os/x86_64 gpgcheck0 enabled1 gpgkeyfile:///et…

基于SpringBoot+SSM苍穹外卖之实战项目

功能介绍: 基于SpringBootSSM苍穹外卖之企业级实战项目。该系统定位的是一款为餐饮企业(餐厅、饭店)定制的软件产品,在线外卖系统,顾客可以通过网站或者手机 App 订购餐点。 主要功能: 管理端 模块描述登…

小红书为什么流量不好,小红书笔记质量评判标准有哪些?

我们都知道小红书平台强大的种草力与传播力,需要依靠优质笔记的输出来达成。但是很多时候,我们撰写了笔记,却无法被收录,获得流量,这都是因为笔记质量出现了问题。那么小红书为什么流量不好,小红书笔记质量…

20PIN直插百兆网络变压器 H82022D

这是一颗20PIN直插百兆网络变压器 PIN距为2.0 ,与H82002D是一样的,但内部线路刚好相反 本产品我司可支持一件代发,并支持出口 专业网络变压器,尽在Hqst

微信小程序分销商城源码系统+带PC端+收银台+付费会员卡 带完整搭建教程

在当今数字化的世界里,微信小程序已成为商业发展的重要一环。而其中,分销商城更是备受商家和消费者青睐的一种业务模式。为了帮助您快速搭建起自己的微信小程序分销商城,小编来给大家分享一款微信小程序分销商城源码系统,带PC端的…

iOS发布证书.p12文件无密码解决办法及导出带密码的新.p12文件方法

摘要: 本文将以iOS技术博主身份,分享解决使用无密码的.p12文件发布应用时遇到的问题,并介绍如何以带密码的方式重新导出.p12文件的方法。通过本文提供的步骤,开发者可以顺利完成证书的发布流程。 引言 在iOS应用发布过程中&…

电脑监控软件系统有哪些

电脑监控软件系统在当今信息化时代的应用越来越广泛,它们可以帮助企业或个人解决许多问题。 电脑监控软件有哪些功能: 1、实时监控:对电脑的屏幕、键盘、鼠标等设备进行实时监控,以便及时发现异常情况并采取相应的措施。 2、数据采…