http缓存浅析及HttpCache使用方法 [ 2.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,有数据的
johnny1991
最后登录:2024-03-05
在线时长:81小时27分
- 粉丝26
- 金钱3285
- 威望580
- 积分9895
共 1 条评论
老哥 厉害 学习了