Comments (2)
什么是http缓存
在用户访问网站第一次进行请求的时候,会将请求数据储存在某个可以快速到达和读取的仓库,再重新请求的时候就会调用仓库里的数据。
http缓存的意义
- 提升数据交换的性能(速度)
- 缓解服务器或数据库的压力
http的缓存策略
- 简单的来说,就是第一次请求的时候,服务器会将请求的数据缓存起来,再次请求的时候,会通过一些方法对比,决定从缓存里面取出数据,还是重新请求。说到这里就要提到两个字段
Expires
和Cache-Control
,这两个字段表示缓存数据的有效期,在决定是否缓存的时候,首先要对比的就是这两个字段是否还在有效期内。 - 复杂一点说,其实http的缓存策略分为两种:强缓存和对比缓存(又称协商缓存):
- 强缓存是会直接从缓存仓库中将数据取出来,无需再次请求数据,使用到的就是上述
Expires
和Cache-Control
这两个字段,方式是比较有效期,Cache-Control
的优先级更高。强缓存的状态码为200,并且在200后通常会有注释from memory cache
(缓存资源在内存中,浏览器关闭后内存中的缓存就会被释放,重新打开页面取不到该缓存。)或者from disk cache
(缓存资源在硬盘中,浏览器关闭后硬盘中的缓存不会消失,下次进入页面还能从硬盘中获取)。 - 对比缓存是需要经过服务器确认是否使用缓存的机制,其http状态码为304。这里涉及到的概念是
Last-Modified / If-Modified-Since
和Etag / If-None-Match
这两种对比标志。Last-Modified / If-Modified-Since
当浏览器第一次访问一个资源的时候,服务器会在response header
中返回一个Last-Modified
,代表这个资源最后的修改时间,当浏览器再次访问这个资源的时候,会在request header
中带上If-Modified-Since
,值为上次请求时服务器返回的Last-Modified
的值,然后服务器根据资源上次修改的时间确认资源在这段期间内是否更改过,如果没有,则返回304,如果有,则返回200并返回最新的资源。Etag / If-None-Match
, 与Last-Modified / If-Modified-Since
的机制类似,不同的是,Etag是通过一个校验码来对比资源是否更改过的,而不是通过资源的修改时间。当一个资源修改时,其校验码也会更改。当浏览器请求资源时,服务器会返回一个Etag字段,然后浏览器下一次请求时,会带上If-None-Match
,值为上次服务器返回的Etag的值,服务器经过校验码的对比后决定返回200或304。
- 强缓存是会直接从缓存仓库中将数据取出来,无需再次请求数据,使用到的就是上述
from daily.
什么是缓存
浏览器缓存(Brower Caching)是浏览器对之前请求过的文件进行缓存,以便下一次访问时重复使用,节省带宽,提高访问速度,降低服务器压力。(简言之,就是告诉浏览器在约定的这个时间前,可以直接从缓存中获取资源而无需跑到服务器去获取)。
HTTP缓存机制主要在http响应头中设置,响应头中相关字段为Expires、Cache-Control、Last-Modified、Etag。
缓存的类别
浏览器缓存分为强缓存和协商缓存
- 强缓存
浏览器不会向服务器发送任何请求,直接从本地缓存中读取文件并返回Status Code: 200 OK;
200 后面会有一些参数 含义是
form memory cache 不访问服务器,一般已经加载过该资源并且缓存在了内存当中,直接从内存中读取缓存数据。关闭浏览器后,数据将不再存在了。
foem disk cache 不访问服务器,已经在之前的某个时间加载过该资源,直接从硬盘中读取缓存,关闭浏览器后,数据依然存在,不会随着页面的关闭而释放掉下次打开是同样的。
访问规则,优先访问memory cache,其次是disk cache, 最后是请求网络资源
- 协商缓存:
向服务器发送请求,服务器会根据这个请求的request header的一些参数来判断是否命中协商缓存,如果命中,则返回304状态码并带上新的request header通知浏览器从缓存中读取资源。
from daily.
Related Issues (20)
- 第二十三题:新窗口打开链接的方法是什么?那么如何使全站链接都打开新窗口? HOT 1
- 第二十四题:介绍一下HTML5中的ruby标签 HOT 2
- 第二十五题:new操作符都做了什么事情? HOT 2
- 第二十六题:你所在的团队有规范吗?举例说明都定义了哪些规范? HOT 1
- 第二十七题:用洗牌算法实现一个打乱数组的方法 HOT 3
- 第二十八题:实现数组的并、交、差、补集这四个方法 HOT 2
- 第二十九题:什么是链表? HOT 1
- 第三十题:两数相加
- 第三十一题:描述一下原型和原型链,以及之间的关系
- 第三十二题:什么是高阶函数? HOT 1
- 第三十三题:柯里化?
- 第三十四题:如何快速的适应新工作?
- 第三十五题:为什么不常用table和iframe这两个元素?
- 第三十六题:聊聊单元测试?
- 第三十七题:void 0 HOT 1
- 第三十八题:BEM 规范 HOT 1
- 第三十九题:Webpack的优缺点 HOT 1
- 第四十题:实现一个Promise HOT 1
- 第四十一题:TypeScript的优劣点 HOT 1
- 第四十二题:React 获取 ref 的方法都有哪些? HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from daily.