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);
}
}