CDN缓存

CDN缓存

Web缓存的种类

–数据库缓存–:

当web应用关系复杂,数据表蹭蹭蹭往上涨时,可以将查询后的数据放到内存中进行缓存,下次再查询时,就直接从内存缓存中获取,从而提高响应速度。

–CDN缓存–:

CDN通俗点,就是当我们发送一个web请求时,会先经过它一道手,然后它帮我们计算路径,去哪得到这些东东(representations)的路径短且快。这个是网站管理员部署的,所以他们也可以将大家经常访问的representations放在CDN里,这样,就响应就更快了。

–代理服务器缓存–:

代理服务器缓存,其实跟下面即将讲的浏览器缓存性质差不多,差别就是代理服务器缓存面向的群体更广,规模更大而已。即,它不只为一个用户服务,一般为大量用户提供服务,同一个副本会被重用多次,因此在减少相应时间和带宽使用方面很有效。

–浏览器缓存–:

简而言之,就是,每个浏览器都实现了 HTTP 缓存,我们通过浏览器使用HTTP协议与服务器交互的时候,浏览器就会根据一套与服务器约定的规则进行缓存工作。当我们点击浏览器上‘后退’或者‘前进’按钮时,显得特别有用。

head头参数

Etag & If-None-Match

Etag是属于HTTP1.1属性,是服务器生成返回给前端
当你第一次发起HTTP请求时,服务器会返回一个Etag

当你第二次发起同一个请求时,客户端会同时发送一个If—None-Match,它的值就是Etag(请求的发起是客户端设置)

服务器对比客户端发送来的Etag是否与服务器的相同,相同就返回304,客户端继续使用本地缓存。不相同返回200,户端重新解析服务器返回的数据。

Etag实体标签:一般是资源实体的哈希值
Etag的优先级高于Last-Modified

Last-Modified & If-Modified-Since

Last-Modified与Etag类似。不过Last-Modified表示响应资源在服务器最后修改时间而已。与Etag相比,不足为:
  (1)、Last-Modified标注的最后修改只能精确到秒级,如果某些文件在1秒钟以内,被修改多次的话,它将不能准确标注文件的修改时间;
  (2)、如果某些文件会被定期生成,当有时内容并没有任何变化,但Last-Modified却改变了,导致文件没法使用缓存;
  (3)、有可能存在服务器没有准确获取文件修改时间,或者与代理服务器时间不一致等情形。
Etag是服务器自动生成或者由开发者生成的对应资源在服务器端的唯一标识符,能够更加准确的控制缓存。

第一次请求网站返回200和Last-Modified
Last-Modified(服务器页面最后修改的时间通过Last-Modified由服务器发往客户端)
第二次请求网站时返回304
客户端会通过If-Modified-Since头将上次服务器返回的最后修改时间发送回去,服务器端通过这个时间判断页面是不是最新的。

你可能感兴趣的:(网络知识)