Nginx缓存设置案例详解


Posted in Servers onSeptember 15, 2021

在开发调试web的时候,经常会碰到因浏览器缓存(cache)而经常要去清空缓存或者强制刷新来测试的烦恼,提供下apache不缓存配置和nginx不缓存配置的设置。在常用的缓存设置里面有两种方式,都是使用add_header来设置:分别为Cache-Control和Pragma。

nginx:
location ~ .*\.(css|js|swf|php|htm|html )$ {
add_header Cache-Control no-store;add_header Pragma no-cache;
}

对于站点中不经常修改的静态内容(如图片,JS,CSS),可以在服务器中设置expires过期时间,控制浏览器缓存,达到有效减小带宽流量,降低服务器压力的目的。

以Nginx服务器为例:

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {
#过期时间为30天,
#图片文件不怎么更新,过期可以设大一点,
#如果频繁更新,则可以设置得小一点。
expires 30d;
}
location ~ .*\.(js|css)$ {
expires 10d;
}

背景】:Expires是Web服务器响应消息头字段,在响应http请求时告诉浏览器在过期时间前浏览器可以直接从浏览器缓存取数据,而无需再次请求。

相关资料

1、Cache-control策略

Cache-Control与Expires的作用一致,都是指明当前资源的有效期,控制浏览器是否直接从浏览器缓存取数据还是重新发请求到服务器取数据。只不过Cache-Control的选择更多,设置更细致,如果同时设置的话,其优先级高于Expires。

http协议头Cache-Control

值可以是public、private、no-cache、no- store、no-transform、must-revalidate、proxy-revalidate、max-age

各个消息中的指令含义如下:

  • Public指示响应可被任何缓存区缓存。
  • Private指示对于单个用户的整个或部分响应消息,不能被共享缓存处理。这允许服务器仅仅描述当用户的部分响应消息,此响应消息对于其他用户的请求无效。
  • no-cache指示请求或响应消息不能缓存
  • no-store用于防止重要的信息被无意的发布。在请求消息中发送将使得请求和响应消息都不使用缓存。
  • max-age指示客户机可以接收生存期不大于指定时间(以秒为单位)的响应。
  • min-fresh指示客户机可以接收响应时间小于当前时间加上指定时间的响应。
  • max-stale指示客户机可以接收超出超时期间的响应消息。如果指定max-stale消息的值,那么客户机可以接收超出超时期指定值之内的响应消息。

Last-Modified/If-Modified-Since

  • Last-Modified/If-Modified-Since要配合Cache-Control使用。
  • Last-Modified:标示这个响应资源的最后修改时间。web服务器在响应请求时,告诉浏览器资源的最后修改时间。
  • If-Modified-Since:当资源过期时(使用Cache-Control标识的max-age),发现资源具有Last-Modified声明,则再次向web服务器请求时带上头 If-Modified-Since,表示请求时间。web服务器收到请求后发现有头If-Modified-Since 则与被请求资源的最后修改时间进行比对。若最后修改时间较新,说明资源又被改动过,则响应整片资源内容(写在响应消息包体内),HTTP 200;若最后修改时间较旧,说明资源无新修改,则响应HTTP 304 (无需包体,节省浏览),告知浏览器继续使用所保存的cache。

其最终达到的就是等效于设置这三类html缓存技术:

<meta http-equiv="pragma" content="no-cache"/>
<meta http-equiv="Cache-Control" content="no-cache, must-revalidate"/> 
<meta http-equiv="expires" content="0"/>

到此这篇关于Nginx缓存设置案例详解的文章就介绍到这了,更多相关Nginx缓存设置内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Servers 相关文章推荐
nginx如何将http访问的网站改成https访问
Mar 31 Servers
Nginx设置日志打印post请求参数的方法
Mar 31 Servers
Windows下使用Nginx+Tomcat做负载均衡的完整步骤
Mar 31 Servers
Nginx配置80端口访问8080及项目名地址方法解析
Mar 31 Servers
Apache Linkis 中间件架构及快速安装步骤
Mar 16 Servers
iSCSI服务器CHAP双向认证配置
Apr 01 Servers
Windows Server 2008 修改远程登录端口以及配置防火墙
Apr 28 Servers
服务器间如何实现文件共享
May 20 Servers
Python安装及建立虚拟环境的完整步骤
Jun 25 Servers
CentOS7 minimal 最小化安装网络设置过程
Dec 24 Servers
解决ubuntu安装软件时,status-code=409报错的问题
Dec 24 Servers
Shell中的单中括号和双中括号的用法详解
Dec 24 Servers
图文详解Nginx版本平滑升级方案
Sep 15 #Servers
Nginx配置文件详解以及优化建议指南
Sep 15 #Servers
学习nginx基础知识
Nginx location 和 proxy_pass路径配置问题小结
Sep 04 #Servers
Nginx使用Lua模块实现WAF的原理解析
Nginx部署vue项目和配置代理的问题解析
centos8安装nginx1.9.1的详细过程
Aug 02 #Servers
You might like
phpmailer在服务器上不能正常发送邮件的解决办法
2014/07/08 PHP
使用XHGui来测试PHP性能的教程
2015/07/03 PHP
JavaScript 函数replace深入了解
2013/03/14 Javascript
Javascript动态引用CSS文件的2种方法介绍
2014/06/06 Javascript
node.js中的fs.statSync方法使用说明
2014/12/16 Javascript
js实现多选项切换导航菜单的方法
2015/02/06 Javascript
JS特效实现图片自动播放并可控的效果
2015/07/31 Javascript
移动手机APP手指滑动切换图片特效附源码下载
2015/11/30 Javascript
AngularJS 使用 UI Router 实现表单向导
2016/01/29 Javascript
深入浅析knockout源码分析之订阅
2016/07/12 Javascript
node.js中的事件处理机制详解
2016/11/26 Javascript
自定义vue全局组件use使用、vuex的使用详解
2017/06/14 Javascript
vue2利用Bus.js如何实现非父子组件通信详解
2017/08/25 Javascript
深入理解Vue Computed计算属性原理
2018/05/29 Javascript
详解easyui 切换主题皮肤
2019/04/04 Javascript
js实现div色块拖动录制
2020/01/16 Javascript
使用Vue-cli 中为单独页面设置背景图片铺满全屏
2020/07/17 Javascript
[02:15]2015国际邀请赛选手档案IG.Ferrari 430
2015/07/30 DOTA
[04:45]DOTA2-DPC中国联赛正赛 iG vs LBZS 赛后选手采访
2021/03/11 DOTA
Python3实现生成随机密码的方法
2014/08/23 Python
Python与shell的3种交互方式介绍
2015/04/11 Python
使用Python脚本在Linux下实现部分Bash Shell的教程
2015/04/17 Python
python中import学习备忘笔记
2017/01/24 Python
Python中工作日类库Busines Holiday的介绍与使用
2017/07/06 Python
Django实现表单验证
2018/09/08 Python
解决sublime+python3无法输出中文的问题
2018/12/12 Python
python样条插值的实现代码
2018/12/17 Python
python使用OpenCV模块实现图像的融合示例代码
2020/04/10 Python
Python Pygame实现俄罗斯方块
2021/02/19 Python
css3实现wifi信号逐渐增强效果实例
2017/08/09 HTML / CSS
html5 Canvas画图教程(11)—使用lineTo/arc/bezierCurveTo画椭圆形
2013/01/09 HTML / CSS
速卖通欧盟:Aliexpress EU
2020/08/19 全球购物
客服文员岗位职责
2013/11/29 职场文书
环保专项行动方案
2014/05/12 职场文书
一年级语文上册复习计划
2015/01/17 职场文书
2015年话务员工作总结
2015/04/29 职场文书