johnny1991 2017-04-24 17:41:13 4389次浏览 1条评论 4 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,有数据的

觉得很赞
您需要登录后才可以评论。登录 | 立即注册