当前位置: 首页 » 综合知识 » it知识 » 正文

基于nginx如何设置浏览器协商缓存

发布时间:2023-07-14 以下文章来源于网友投稿,内容仅供参考!

强缓存与协商缓存的区别

  强缓存:浏览器不与服务端协商直接取浏览器缓存

  协商缓存:浏览器会先向服务器确认资源的有效性后才决定是从缓存中取资源还是重新获取资源

协商缓存运作原理

  现在有一个这样的业务情景:后端的静态资源会不定时地发生更新,而因为浏览器默认使用强缓存,会默认从浏览器缓存中取到过时的资源。

  现在我们希望浏览器每次获取资源的时候都向后端确认资源是否更新,就要设置浏览器使用协商缓存

  那么后端如何判断资源是否更新了呢?这时就要用到etag和last-modified两项响应头。

  每次收到一个静态资源的请求时,后端都将资源的最后修改时间(last-modified)、根据资源内容计算出来的etag放在响应头给前端。

  前端收到响应后将这两项缓存起来,然后在下次请求同样资源的时候,将这两项的内容放到if-modified-since和if-none-match这两项请求头中。

  服务端收到这两项后,会与资源当前生成的etag和last-modified做比较,如果两者都一致,说明资源没有更新,服务端会返回304空响应;否则,说明资源有更新,服务端会将完整的资源内容返回

实现

  那么如何实现这样一个复杂的过程呢?其实很简单,只要使用nginx作为静态资源的服务器,再在响应头加上cache-control:no-cache就可以了。

  下面来分步骤实现一下

  1. 使用nginx作为静态资源的服务器

    在nginx的配置中,将对静态资源的请求映射到资源的磁盘路径上

http {
  server {
  listen 80;
  ...
  location /picture/ {
    alias d:/luozixi/tcp_test/picture/;
    # alias是重定义路径
    # 比如访问127.0.0.1/picture/1_new.gif,则会映射为访问d:/luozixi/tcp_test/picture/1_new.gif
    # web应用根本不会收到请求,picture的请求都被nginx处理了
    # alias是替换,root是拼接
    autoindex on;
    # 访问127.0.0.1/picture/,会得到目录的索引界面
    }
  }
}

  2. 重新加载nginx配置

nginx -s reload

  3. 此时,请求静态资源的时候nginx会自动在response头中加上etag和last-modified两项

  

  4. 但是这时发现,如果不配置cache-contrl: no-cache,浏览器在下次请求这个资源的时候不会将请求发向后端,而是直接从缓存中获取资源

  5. 在nginx中配置

location /picture/ { 
  add_header cache-control no-cache;
  alias d:/luozixi/tcp_test/picture/; 
}

  6.清除浏览器缓存后第一次发起请求,会得到一个正常的200 response,而且响应头里已经有了cache-control: no-cache,表示使用协商缓存

  7.再次发起请求后,会发现请求头已经带上了if-modified-since和if-none-match两项

  

  8.服务端(nginx)收到这两项后,会与资源当前生成的etag和last-modified做比较,如果两者都一致,说明资源没有更新,服务端会返回304空响应;否则,说明资源有更新,服务端会将完整的资源内容返回

    另外,服务器验证if-modified-since的方式只是简单的字符串比较,即使资源的last-modified比if-modified-since要早,服务端仍认为资源有更新

  9.浏览器在收到304响应后,会从浏览器缓存中取资源。因此速度非常块

  

no-cache与no-store的区别

  no-cache表示不缓存过期资源,缓存会向服务器进行有效处理确认之后处理资源

  而no-store才是真正的不进行缓存。

  • • Linux Ecdsa密钥长度选择有何依据

    在Linux

  • • Linux Khook在内核监控中的应用如何

    Linux

  • • Linux Gsoap是否支持异步通信

    GSOAP是

  • • Linux Coremail如何提升用户体验

    提升Linu

  • • Linux Ecdsa算法有哪些局限性

    ECDSA

  • 哎呀音乐钢琴键盘学习《 钢琴主人训练营》 西瓜学琴
    郭蝈 陪练钢琴 30节课时 考级刚需 让孩子每一次练琴都是高质量的
    30天轻松学会五线谱 流行钢琴自学初级教程 牙牙学琴
    流行爵士钢琴实战技巧VIP课 - 继伟 哎呀音乐
    【海上钢琴师】原版 MT1990钢琴谱
    百首经典流行钢琴实战曲集 - 继伟
    雷费尔德电钢琴重锤88键专业考级儿童初学者数码电子钢琴家用
    小练咖 真人钢琴陪练 1v1服务 2999随时退 1课时50分钟 考级刚需
    雅马哈电钢琴88键重锤CLP735智能数码电子钢琴家用专业初学者考级
    【原装进口】Yamaha/雅马哈钢琴 b121 SC2原声静音钢琴
  • 珠海专业调钢琴
  • 天津宝坻区调钢琴
  • 天津静海区钢琴调音
  • 成都简阳市钢琴调律
  • 大连瓦房店市钢琴调音
  • 眉山调钢琴联系方式
  • 惠州大亚湾钢琴调琴师
  • 长治调琴师
  • 厦门湖里区钢琴调音师
  • 上海普陀区钢琴调音师