首页 > Web开发 > 详细

http缓存浅析及HttpCache使用方法 [ 2.0 版本 ]

时间:2018-10-19 00:58:33      阅读:153      评论:0      收藏:0      [点我收藏+]

1.学习理由:合理的利用http缓存在对网站性能提升有非常巨大的作用,而且十分经济实惠 2.http缓存浅析 3.如何使用HttpCache来实现http缓存

http缓存浅析 1.当客户端第一次访问网站的时候,浏览器是没有缓存的,所以所有的资源都是从服务器获取的(会将css,js,图片)等资源缓存到客户端的本地 2.当客户端第二次以后访问网站的时候,会先去先去检查本地有没有有效缓存, a.如果在客户端就可以确定是有效缓存的话,那么就不会去请求服务器(通过http header expires信息来确定) b.如果客户端无法确定是不是有效缓存的话,就会请求服务器验证,在服务器端验证有两种验证方式,etag/HTTP_IF_NONE_MATCH和lastmodified/HTTP_IF_MODIFIED_SINCE, 优先使用etag验证,etag不通过会使用lastmodified的,如果验证通过,会返回304(表示资源没有变化),304是没有body信息,所以传输数据量非常小,对服务器的压力特别小, 如果验证不通过,则会去请求资源,返回200,这个会带有Body,所以数据量会比较大,对web优化是没有效果的

3.如何使用http缓存协议优化web a.首先我们可以将一些永远不会变化的资源,在其action里面通过设置比较大的expires来是这个资源在很长的时间里面是有效的,设置方法如下 $response->getHeaders()->set(‘Expires‘, ‘Mon, 01 May 2017 08:31:23 GMT‘); b.其次,对于一些不常变化的网站资源,我们可以使用yii提供的HttpCache,来设置他的lastmodified或etag来优化网站,代码如下:

public function behaviors() { return [ [ ‘class‘ => ‘yii\filters\HttpCache‘, ‘only‘ => [‘index‘], ‘lastModified‘ => function ($action, $params) { $q = new \yii\db\Query(); return $q->from(‘post‘)->max(‘updated_at‘); }, ], ]; }

解释一下,这个代码的意思,在客户端访问,index这个action的时候,会在http的头部加上一个lastmodified的验证,这里用到了http缓存原理的第二条: 1.如果post表的最大的updated_at没有变化,那么返回客户端304,没有数据的 2.如果post表的最大的updated_at有变化,那么放回200,有数据的

http缓存浅析及HttpCache使用方法 [ 2.0 版本 ]

原文:https://www.cnblogs.com/weisliey/p/9813733.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!