配置调优IIS6+gzip+varnish-2.0.6[原创] 不指定

root , 2009/12/25 23:20 , Varnish , 评论(3) , 阅读(28637) , Via 本站原创 | |
一、启用IIS6 Gzip模块
1.1、在 "IIS 管理器" 中,打开 "网站 > 属性" 对话框,切换到 "服务" 页卡,选中压缩应用程序文件(社区页面不做静态文件的压缩)压缩选项。点击在新窗口中浏览此图片

1.2、新增一个服务扩展,路径为 "c:\windows\System32\inetsrv\gzip.dll"。添加完成后,允许该扩展使用。
点击在新窗口中浏览此图片

1.3、用记事本打开 "%windir%\system32\inetsrv\MetaBase.xml",找到 "IIsCompressionScheme",按下述方法修改、保存。(建议修改前先做备份)如果需要压缩动态文件,则将 HcDoDynamicCompression设置为"TRUE",并在HcScriptFileExtensions中增加您要压缩的动态文件后缀名,如asp (由于我要优化的系统中,做了shtml->asp的URL Rewrite,所以将 shtml、asp 也加入了)。
如果需要压缩静态文件,则将HcDoStaticCompression和HcDoOnDemandCompression设置为 "TRUE",并在HcFileExtensions中增加您需要压缩的静态文件后缀名,如xml、css等。HcDynamicCompressionLevel和HcOnDemandCompLevel表示需要的压缩率,数字(0~9)越小压缩率越低。

1.5、测试
使用HttpWatch Professional 6.0.14看看启用 GZip 后的效果。
点击在新窗口中浏览此图片

二、安装配置Vanish 2.0.6(最新版)
2.1、安装
(略)

2.2、调优sysctl.conf
(略)

2.3、修改varnish配置
vi /usr/local/varnish/etc/vcl.conf
引用

backend wwwserver {
       .host = "192.168.100.5";
       .port = "80";
}
acl purge {
       "localhost";
       "127.0.0.1";
       "192.168.0.0"/16;
}
sub vcl_recv {
       if (req.request == "PURGE") {
               if (!client.ip ~ purge) {
                       error 405 "Not allowed.";
               }
               lookup;
       }
if (req.http.host ~ "^(cache.sina.com.cn)") {
               set req.backend = wwwserver;
               if (req.request != "GET" && req.request != "HEAD") {
                       pipe;
               }
               else {
                       lookup;
               }
       }
       else {
               error 404 "sina.com.cn.cn cache server";
               lookup;
       }
}
sub vcl_hit {
       if (req.request == "PURGE") {
               set obj.ttl = 0s;
               error 200 "Purged.";
       }
}
sub vcl_miss {
       if (req.request == "PURGE") {
               error 404 "Not in cache.";
       }
}
sub vcl_fetch {
       if (req.request == "GET" && req.url ~ "\.(txt|js)$") {
               set obj.ttl = 3600s;
       }
       else {
               set obj.ttl = 300s;
       }
}
sub vcl_deliver {
        if (obj.hits > 0) {
                set resp.http.X-Cache = "HIT";
        } else {
                set resp.http.X-Cache = "MISS";
        }
}


2.4命中率分析
点击在新窗口中浏览此图片

2.5、现象分析
1) 名词解释
Cache hits:缓存命中
Cache hits for pass:从背端服务器获取数据但无法被缓存
Cache misses:非命中
2) 分析
发现缓存结果数据比较奇怪的现象,不能缓存的对象还比命中的对象多得多,非命中数在正常值内。
3)排查过程
3.1、CURL命令测试,如curl -I http://www.sina.com.cn/index.shtml -H Accept-Encoding:gzip,defalte
点击在新窗口中浏览此图片

结果分析:发现每次response header中set Cookie都不一样,如此varnish会认为每次请求的都是不同对象,这一点跟squid有区别,squid会直接忽略cookie的判断。同样可以从X-cache:MISS中看到该对象没有被命中及不被Cache Hit。Content-Encoding:gzip,说明varnish已经支持了http1.1,成功将backend server 的gzip结果返回给客户端。

3.2、删除Varnish cookie请求
引用

sub vcl_fetch {
       remove obj.http.Set-Cookie;
       if (req.request == "GET" && req.url ~ "\.(txt|js)$") {
               set obj.ttl = 3600s;
       }
       else {
               set obj.ttl = 300s;
       }
}

3.3、继续测试
点击在新窗口中浏览此图片
[图1]

点击在新窗口中浏览此图片
[图2]

结果分析:上图1为第一次请求URL,Vanish返回结果中可以看出没有被命中,属正常。图2为第二次请求同一URL,发现此次已经被HIT了。另两次response.head已经没有response cookie了,问题解决。
再看看Varnish缓存状态:
点击在新窗口中浏览此图片

结果分析:结果已正常,Cache hits for pass已经没有了,命中率还是比较理想的。

:Varnish2.x版本后的语法、启动方式、优化项等与1.x相差有较大的差异,在以后实战中慢慢去体会到吧。stupid
Tags: ,
zzh Email
2009/12/28 10:30
为什么我想转载你的文章,图片都提示防盗链啊?怎么复制粘贴也不行
刘天斯 回复于 2009/12/28 15:22
平台做了防盗链,请提供你的域名,我开放访问允许即可。
reset
2009/12/26 16:53
搞定了,谢谢!!多多向你学习。
reset
2009/12/26 13:53
你好,我安装过这个版本,启动没问题,但访问奇慢无比,后来换成1.1的就没问题了。怎么回事??
root 回复于 2009/12/26 14:08
2.X以后的版本你可以用源码包的启动脚本,具体操作请参考http://bbs.linuxtone.org/thread-1433-1-2.html
分页: 1/1 第一页 1 最后页
发表评论

昵称

网址

电邮

打开HTML 打开UBB 打开表情 隐藏 记住我 [登入] [注册]