conn.recv()参数值设置 缓存_Nginx常用模块---ngx_http_headers_module设置HTTP响应头

本文介绍了Nginx的ngx_http_headers_module模块,重点讲解了expires指令和add_header指令的用法,用于设置HTTP响应头,控制浏览器和CDN的缓存策略。通过示例展示了如何根据Content-Type动态调整缓存时间,并解释了always参数的作用。
摘要由CSDN通过智能技术生成

c32e6474518523fb3e670be4e209f991.png

HTTP头信息,是实际业务中一个很重要的功能。例如,如果需要将请求结果在浏览器上缓存一段时间,或者在请求代理到后端服务器的过程中生成一个唯一的 ID进行识别。通过对 Nginx进行配置,可以轻松实现这些功能。

ngx_http_headers_module是在 Nginx编译时默认自带的模块,主要包含 add_header和 expires两个指令。

使用语法

expires

expires语法: expires [modified] time; expires epoch | max | off;

默认值: expires off;

环境: http、 server、 location、 if in location

用途:设置 Expires和 Cache-Control响应头字段,主要作用是控制缓存时间,如在浏览器上的缓存时间、 CDN的缓存时间。参数值可以是正数、负数或零;

示例如下:

b4e2ace86556d3f0ca4adcbb68ffb7b4.png

如果要求在浏览器第一次访问后,数据在浏览器上缓存 1h,则配置如下:

3e885e6f03e789733d7ba40d50e6b191.png

此配置只能在 HTTP状态码是 200、 201、 204、 206、 301、 302、 303、 304、 307或 308时才会生效。

即只有当请求处于正常的返回状态时,才会发送缓存头,毕竟在浏览器上缓存一个错误状态不是什么好事情。

在 Nginx 1.7.9版本之后, expires指令可以使用变量来配置响应头,并根据响应头的 Content-Type来定义缓存时间,也就是可以根据不同的条件动态地调整缓存时间。

例如,如果 Content-Type是 application/ pdf,则添加 cache-control: max-age = 3600响应头信息;如果 Content-Type是 image/,则添加 ache-control: max-age = 36000响应头信息;如果没有匹配到对应的 Content-Type,则执行 default的配置 off,即不进行缓存,代码如下:

dc773c6540de225730ada5c6c2532306.png

6bc46d6a3fd43cd917ee2ab1cf3645ea.png

在上述配置中, map指令会根据响应头 Content_ Type的值对 $expires进行赋值(通过 $ sent_ http_ content_ type获取 Content-Type的值)。

add_ header

语法: add_ header name value [always];

默认值:无

环境: http、 server、 location、 if in location

用途:添加自定义的响应头。

例如,可以用来添加 Cache-Control响应头,以达到 expires指令的效果,不过它不如 expires那样简洁、明了。

示例如下:

d75bc9b3dcc941cf482ca0117354e609.png

在默认情况下, add_ header只能在 HTTP状态码是 200、 201、 204、 206、 301、 302、 303、 304、 307或 308时输出响应头,如果出现 404、 500等异常状态码则无法输出响应头。

但 Nginx 1. 7. 5以上的版本新增了 always参数,使之可以在任何 HTTP状态下输出响应头,示例如下:响应头信息输出如下:测试结果表明,即使发生了 500错误,加入 always参数后依然可以输出 add_header响应头信息。

164ace0b2a10e42a8e690e36f0aaf0e9.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值