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+Tomcat实现负载均衡、动静分离的原理解析
Mar 31 Servers
nginx优化的六点方法
Mar 31 Servers
详解Nginx启动失败的几种错误处理
Apr 01 Servers
nginx部署多前端项目的几种方法
May 25 Servers
Minikube搭建Kubernetes集群
Mar 31 Servers
tomcat下部署jenkins的方法
May 06 Servers
Nginx限流和黑名单配置
May 20 Servers
Apache SeaTunnel实现 非CDC数据抽取
May 20 Servers
教你如何用cmd快速登录服务器
Jun 10 Servers
windows server 2016 域环境搭建的方法步骤(图文)
Jun 25 Servers
Docker安装MySql8并远程访问的实现
Jul 07 Servers
Nginx跨域问题解析与解决
Aug 05 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
FCKeditor添加自定义按钮
2008/03/27 PHP
php中通过正则表达式下载内容中的远程图片的函数代码
2012/01/10 PHP
php bootstrap实现简单登录
2016/03/08 PHP
Laravel框架Eloquent ORM删除数据操作示例
2019/12/03 PHP
浅析PHP echo 和 print 语句
2020/06/30 PHP
prototype 学习笔记整理
2009/07/17 Javascript
jQuery.ajax 用户登录验证代码
2010/10/29 Javascript
js原型链原理看图说明
2012/07/07 Javascript
原生js编写设为首页兼容ie、火狐和谷歌
2014/06/05 Javascript
JavaScript和CSS交互的方法汇总
2014/12/02 Javascript
详解JavaScript对W3C DOM模版的支持情况
2015/06/16 Javascript
js获取页面引用的css样式表中的属性值方法(推荐)
2016/08/19 Javascript
NodeJS使用formidable实现文件上传
2016/10/27 NodeJs
vue.js+Element实现表格里的增删改查
2017/01/18 Javascript
canvas 实现中国象棋
2017/02/17 Javascript
js实现点击切换checkbox背景图片的简单实例
2017/05/08 Javascript
JS中的BOM应用
2018/02/02 Javascript
layui下拉列表select实现可输入查找的方法
2019/09/28 Javascript
小程序实现投票进度条
2019/11/20 Javascript
[01:15:56]2018DOTA2亚洲邀请赛3月30日 小组赛A组 TNC VS Newbee
2018/03/31 DOTA
python编写网页爬虫脚本并实现APScheduler调度
2014/07/28 Python
Python实现将DOC文档转换为PDF的方法
2015/07/25 Python
python、java等哪一门编程语言适合人工智能?
2017/11/13 Python
解决seaborn在pycharm中绘图不出图的问题
2018/05/24 Python
对python3 sort sorted 函数的应用详解
2019/06/27 Python
python3使用print打印带颜色的字符串代码实例
2019/08/22 Python
python 实现list或string按指定分段
2019/12/25 Python
英国护发和美妆在线商店:Klip Shop
2019/03/24 全球购物
美国基督教约会网站:ChristianCafe.com
2020/02/04 全球购物
单位消防安全制度
2014/01/12 职场文书
《菜园里》教学反思
2014/04/17 职场文书
廉洁家庭事迹材料
2014/05/15 职场文书
群众路线查摆问题整改措施
2014/10/10 职场文书
2014年劳动部工作总结
2014/12/11 职场文书
大国崛起观后感
2015/06/02 职场文书
一起来学习Python的元组和列表
2022/03/13 Python