作者:洛特大人_382 | 来源:互联网 | 2014-05-28 12:03
varnish3.0之前的版本是根据客户端是否支持gzip,从后端获取压缩或未压缩的内容。如果不在vcl_hash中进行单独设置,还会导致发送给不支持压缩的客户端压缩过的数据,导致乱码。而这次3.0改进后已经完全支持压缩,并根据客户端自动进行解压。varnish3.0下载地
varnish3.0之前的版本是根据客户端是否支持gzip,从后端获取压缩或未压缩的内容。如果不在vcl_hash中进行单独设置,还会导致发送给不支持压缩的客户端压缩过的数据,导致乱码。而这次3.0改进后已经完全支持压缩,并根据客户端自动进行解压。
varnish3.0下载地址
https://www.varnish-cache.org/releases/varnish-cache-3.0.0
先看下日志记录
1 未经过varnish代理的页面访问
支持压缩
192.168.56.1 - - [12/Jul/2011:19:13:54 +0800] "GET / HTTP/1.1" 200
98
"-" "Mozilla/5.0 (Windows NT 5.1; rv:5.0) Gecko/20100101 Firefox/5.0" "-"
用curl模拟不支持压缩
192.168.56.1 - - [12/Jul/2011:19:15:03 +0800] "GET / HTTP/1.1" 200
1338
"-" "curl/7.21.6 (i386-pc-win32) libcurl/7.21.6 OpenSSL/0.9.8q zlib/1.2.5" "-"
可以看到获取的内容长度分别是98Bytes和1338Bytes
2 经过varnish代理后的后端访问
支持压缩
127.0.0.1 - - [12/Jul/2011:19:18:23 +0800] "GET / HTTP/1.1" 200
98
"-" "Mozilla/5.0 (Windows NT 5.1; rv:5.0) Gecko/20100101 Firefox/5.0" "192.168.56.1"
用curl模拟不支持压缩
127.0.0.1 - - [12/Jul/2011:19:19:52 +0800] "GET / HTTP/1.1" 200
98 "-"
"curl/7.21.6 (i386-pc-win32) libcurl/7.21.6 OpenSSL/0.9.8q zlib/1.2.5" "192.168.56.1"
这次看到返回的内容长度都是98Bytes
varnishlog中的请求内容如下
12 TxHeader b User-Agent: curl/7.21.6 (i386-pc-win32) libcurl/7.21.6 OpenSSL/0.9.8q zlib/1.2.5
...
12 TxHeader b Accept: */*
...
12 TxHeader b Accept-Encoding: gzip
而curl发送请求时,header中是不包括“Accept-Encoding:
gzip”的。所以,当varnish请求后端时会自动为不支持gzip的客户端增加“Accept-Encoding:
gzip”,同时在varnish发送给客户端时再进行解压缩:
11 TxHeader c Server:
nginx
...
11 TxHeader c
Transfer-Encoding: chunked
...
11 Gzip c
U D - 87 1338 80 80 632
U D - 87 1338 80 80 632
U代表Gunzip,解压文件
D代表Deliver,分发内容
详细gzip日志说明见https://www.varnish-cache.org/docs/trunk/reference/vsl.html#gzip-records
同时从访问日志中看到,这次更新已经默认支持Transfer-Encoding: chunked方式。
另外varnish配置文件中的vcl_hash方法也做了语法变更,直接使用hash_data即可:
sub vcl_hash {
hash_data(req.url);
if (req.http.host) {
hash_data(req.http.host);
} else {
hash_data(server.ip);
}
}