http缓存机制及其原理

栏目: 后端 · 前端 · 发布时间: 7年前

内容简介:http 缓存机制作为Web性能优化的重要手段, 是计算机知识体系中的一个基础的环节, 同时也是前端架构师同学的必备技能为方便大家理解,我们可以认为浏览器存在一个缓存数据库,用于存储缓存信息. 在客户端第一次请求数据时,此时缓存数据库中没有对应的缓存数据,需要请求服务器,服务器返回后,将数据存储至缓存数据库中根据是否需要重新向服务器发起请求来分类(强制缓存, 对比缓存)。 首先通过时序图的方式, 对他们有个简单的了解:

http 缓存机制作为Web性能优化的重要手段, 是计算机知识体系中的一个基础的环节, 同时也是前端架构师同学的必备技能

缓存规则解析

为方便大家理解,我们可以认为浏览器存在一个缓存数据库,用于存储缓存信息. 在客户端第一次请求数据时,此时缓存数据库中没有对应的缓存数据,需要请求服务器,服务器返回后,将数据存储至缓存数据库中

http缓存机制及其原理

根据是否需要重新向服务器发起请求来分类(强制缓存, 对比缓存)。 首先通过时序图的方式, 对他们有个简单的了解:

已存在缓存数据

仅基于强制缓存,请求数据的流程如下:

http缓存机制及其原理
http缓存机制及其原理

仅基于对比缓存,请求数据的流程如下:

http缓存机制及其原理
http缓存机制及其原理

可以看到,强制缓存如果生效,不需要再和服务器发生交互,而对比缓存不管是否生效,都需要与服务端发生交互

当执行强制缓存的规则时,如果缓存生效,直接使用缓存,不再执行对比缓存规则

强制缓存

在没有缓存数据的时候,浏览器向服务器请求数据时,服务器会将数据和缓存规则一并返回, 缓存规则信息包含在响应header中

浏览器是如何判断缓存数据是否失效呢

强制缓存来机制中,响应header中会有两个字段来标明失效规则

  • Expires/Cache-Control

Expires 是HTTP 1.0的东西,现在默认浏览器均默认使用HTTP 1.1,所以它的作用基本忽略。HTTP 1.1 的版本中,使用Cache-Control替代

对比缓存

顾名思义,需要进行比较判断是否可以使用缓存

http缓存机制及其原理
http缓存机制及其原理

通过两图的对比,我们可以很清楚的发现,在对比缓存生效时,状态码为304,并且报文大小和请求时间大大减少。 原因是,服务端在进行标识比较后,只返回header部分,通过状态码通知客户端使用缓存,不再需要将报文主体部分返回给客户端

对比缓存标识一共分为两种标识传递:

  • Last-Modified / If-Modified-Since
  • Etag / If-None-Match(优先级高于Last-Modified / If-Modified-Since)

Etag

服务器响应请求时,告诉浏览器当前资源在服务器的唯一标识(生成规则由服务器决定)

http缓存机制及其原理
If-None-Match

再次请求服务器时,通过此字段通知服务器客户段缓存数据的唯一标识

服务器收到请求后发现有头If-None-Match 则与被请求资源的唯一标识进行比对, 不同,说明资源又被改动过,则响应整片资源内容,返回状态码200; 相同,说明资源无新修改,则响应HTTP 304,告知浏览器继续使用所保存的cache

http缓存机制及其原理

以上所述就是小编给大家介绍的《http缓存机制及其原理》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

人本界面

人本界面

(美)拉斯基(Jef Raskin) / 史元春 / 机械工业出版社 / 2004-1-1 / 28.0

如果我们想克服目前人机界面上的固有缺陷,就很有必要理解本书的教义;若无此愿望,读读也无妨。交互设计的许多重要方面此书并没有包括在内,因为许多文献中都已经有详尽的阐述。本书的意图是补充现有的界面设计的方法或预测未来。  本书概述了人机界面设计领域的研究成果,详细论证了界面设计思想应以认知学为基础,并考虑人类的心智特点,在指出当前界面设计中弊端的同时,提出了新产品开发的思路。本书集计算机科学、人体工程......一起来看看 《人本界面》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具