Nginx 手记(六)浏览器缓存

一、浏览器缓存

HTTP协议定义的缓存机制(如:Expires;Cache-control等)
1、客户端无缓存
浏览器第一次请求的时候,是没有缓存的,所以会向服务端发起请求获取资源
2、客户端有缓存
浏览器第二次请求的时候,客户端是有缓存的,那么会先在本地校验文件是否过期,如果缓存文件过期,则会请求服务器并进行校验是否修改,如果修改返回新的内容,没修改则会返回304 直接从本地缓存读取,有修改则返回200 并返回新的内容。

二、校验过期机制

1、客户端-校验是否过期:      Expires(1.0版本)、Cache-Control(max-age) (1.1版本)
2、服务端-协议中Etag头信息校验:    Etag(字符串)
3、服务端-Last-Modified头信息校验: Last-Modified(文件修改时间)。不能精准到1s内修改的判断,需要Etag解决

三、配置

在server中的location进行配置
#匹配js和css文件,并设置缓存过期时间为24小时
location ~ .*\.(js|css)$ {
    expires 24; #设置缓存时间为24小时
    #...
}
浏览器控制可以查看相应信息

Response Headers
view source
Accept-Ranges:bytes
Cache-Control:max-age=86400     #nginx中设置的24小时缓存时间
Connection:keep-alive
Content-Length:2543
Content-Type:application/javascript
Date:Mon, 28 Aug 2017 18:21:08 GMT
ETag:"599be4bb-9ef"
Expires:Tue, 29 Aug 2017 18:21:08 GMT
Last-Modified:Tue, 22 Aug 2017 08:00:59 GMT
Server:nginx/1.12.1

转载于:https://my.oschina.net/magicalSam/blog/1526144

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值