资讯专栏INFORMATION COLUMN

浏览器缓存策略

lolomaco / 1697人阅读

摘要:开启之后,浏览器在第一次将资源请求之后会缓存。在响应头中,用于指示代理和使用何种缓存策略。在该时间内则使用缓存。题外话在使用对浏览器缓存进行测试过程中发现。在不设置的情况下,浏览器会根据自身的情况去取舍相关的缓存,可以从这查看。

为了提高站点的访问速度,使用缓存来优化。缓存主要分为 强缓存和协商缓存。

协商缓存

主要分为last-modified、etag。下面我主要通过代码修改来表现各个缓存之间的区别。先讨论协商缓存。last-modified表示文件的修改日期,如果文件做了修改那就应该重新获取文件。last-modified是文件修改后根据服务器的时间生成。

如果我们修改了文件则会重新获取,status就为200

再次刷新就会返回304表示缓存已经是最新不需要再更新。
请求中会询问相关文件修改时间(If-Modified-Since)

请求

响应

ETag:是一个可以与Web资源关联的记号(token)

如果文件被替换,就会生成唯一的etag。

替换前的文件

替换后的文件

PS: 如果是使用了多台服务器做负载均衡的话,会出现etag不一致问题。Apache 的默认ETag的值总是由文件的索引节点(Inode)、大小(Size)、最后修改时间(MTime)决定,我们只需要去掉Inode即可

强缓存

强缓存相比协商缓存更为彻底,在强缓存下浏览器不会对服务器发起请求。

强缓存:主要分为expires和cache-control

Expires: 表示存在时间,允许客户端在这个时间之前不去检查(发请求),等同max-age的 效果。但是如果同时存在,则被Cache-Control的max-age覆盖。 格式: Expires :时间,后面跟一个时间或者日期,超过这个时间后缓存失效。也就是浏览器发出请求之前,会检查这个时间是否失效,若失效,则浏览器会重新发出请求。

开启apache expires_mod之后,浏览器在第一次将资源请求之后会缓存。

Cache-Control
Cache-Control 在 HTTP 响应头中,用于指示代理和 UA 使用何种缓存策略。比如:

no-cache 为本次响应不可直接用于后续请求(在没有向服务器进行校验的情况下)

no-store 为禁止缓存(不得存储到非易失性介质,如果有的话尽量移除,用于敏感信息)

public为大家都可以缓存。

private为仅 UA 可缓存

cache-control中设置max-age 为最长的缓存时间。在该时间内则使用缓存。

设置为no-cache之后则不会再进行缓存。

题外话

在使用apache对浏览器缓存进行测试过程中发现。在不设置 cache-control的情况下,浏览器会根据自身的情况去取舍相关的缓存,可以从这查看。如果大家在服务器配置过程中发现,自己没有配置任何的缓存信息但是浏览器却缓存了资源就不用惊讶。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/103282.html

相关文章

  • 图解 HTTP 的缓存机制 | 实用 HTTP

    摘要:缓存缓存主要是通过请求和响应报文头中的对应信息,来控制缓存的策略。就会返回一个的状态码,表示可以继续使用客户端本地缓存的数据,并刷新超时时间。与之相对的,则表示当前响应是针对单个用户的,并非通用数据,因此不建议任何中间缓存对其进行缓存。 showImg(https://segmentfault.com/img/remote/1460000015383634?w=1080&h=720);...

    zhouzhou 评论0 收藏0
  • 借用workbox实现离线缓存应用

    摘要:已经得到越来越多的浏览器的支持,包括苹果腾讯的内核。苹果从开始,已经开始支持了。针对各种应用场景的多种缓存策略。在无网络环境的情况,也可以做到离线缓存的效果,极大地提升页面的用户体验。 什么是workbox,workbox有什么用途,为什么要使用它?在介绍workbox之前,我们来先大致了解一下service worker,有助于我们后面更好地去理解workbox。 一. servic...

    villainhr 评论0 收藏0
  • 01缓存-缓存是什么

    摘要:在这里所讲的缓存是计算机设备的缓存。三缓存的特征命中率命中率返回正确结果数请求缓存次数,命中率问题是缓存中的一个非常重要的问题,它是衡量缓存有效性的重要指标。 前言: 对于工作经验仅仅只有一年的我来说, 写这篇文章有些吃力,并且感觉有些理解还不够透彻,但是还是铆足了劲想啃啃缓存这块硬骨头。缓存是性能优化的一个必经之路,可以说用好了缓存,性能优化的路就走完一半了。 一、系统缓存 在知乎...

    AaronYuan 评论0 收藏0
  • Nginx与览器缓存

    摘要:与浏览器缓存一浏览器对缓存的处理选项控制请求服务器策略是忽略资源的缓存策略的情况下额外强制请求服务器的意思。而节点只针对中的配置会覆盖的配置。Nginx与浏览器缓存 一、浏览器对缓存的处理:Internet选项   ★ 控制请求服务器策略:是忽略资源的缓存策略的情况下额外强制请求服务器的意思。     ★ 检查存储的页面较新版本          1.每次访问网页时             ...

    jerry 评论0 收藏0
  • 览器缓存策略

    摘要:开启之后,浏览器在第一次将资源请求之后会缓存。在响应头中,用于指示代理和使用何种缓存策略。在该时间内则使用缓存。题外话在使用对浏览器缓存进行测试过程中发现。在不设置的情况下,浏览器会根据自身的情况去取舍相关的缓存,可以从这查看。 为了提高站点的访问速度,使用缓存来优化。缓存主要分为 强缓存和协商缓存。 协商缓存 主要分为last-modified、etag。下面我主要通过代码修改来表现...

    wow_worktile 评论0 收藏0

发表评论

0条评论

lolomaco

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<