Varnish 缓存

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Varnish 缓存相关的知识,希望对你有一定的参考价值。

Centos 6.5  varnish


源码编译需要安装以下的依赖:

报错:
./autogen.sh
./autogen.sh: line 47: libtoolize: command not found
安装依赖:
 yum install libtool*
报错:
 configure: error: requires an X/Open-compatible Curses library
安装依赖:
 yum install ncurses-devel -y
报错:
 configure: error: neither libedit nor another readline compatible library found
安装依赖:
 yum install libedit-devel -y


rpm包安装所需的依赖:


1、安装varnish所需lib,

 rpm --nosignature -i http://repo.varnish-cache.org/redhat/varnish-4.0/el6/x86_64/varnish/varnish-libs-4.0.0-1.el6.x86_64.rpm


2、安装jemalloc,库文件可到此链接处下载:ftp-hk.tmapy.cz/fedora/epel/6/x86_64/jemalloc-3.6.0-1.el6.i686.rpm


rpm --nosignature -i http://ftp-hk.tmapy.cz/fedora/epel/6/x86_64/jemalloc-3.6.0-1.el6.x86_64.rpm


#可以去下载合适自己的varnish版本软件包

http://repo.varnish-cache.org/redhat/varnish-4.0/el6/x86_64/varnish/


3、开始安装,

rpm --nosignature -i http://repo.varnish-cache.org/redhat/varnish-4.0/el6/x86_64/varnish/varnish-4.0.0-1.el6.x86_64.rpm


安装完成后,启动varnish:

service varnish start


HTTP 请求的类型有几种,下面是主要的几种: 

GET : 请求指定的页面信息,并返回实体主体。 

HEAD: 只请求页面的首部。 

POST: 请求服务器接受所指定的文档作为对所标识的URI的新的从属实体。 



pass和pipe都从后端服务器取数据,它们之间有什么不同呢?  

答:当vcl_recv调用 pass 函数时,pass将当前请求直接转发到后端服务器。而后续的请求仍然

通过varnish处理。 

例如,建立了HTTP连接之后,客户端顺序请求 a.css 、a.png两个文件,“当前请求”指的是第一个

请求,即a.css,a.css被直接转发到后端服务器,不被缓存。而后续的a.png则再由varnish来做

处理,varnish会判断a.png 如何处理。 

总结:一个连接中除了当前请求,其它请求仍然按照正常情况由varnish处理。 

 

而pipe模式则不一样,当vcl_recv判断 需要调用 pipe 函数时,varnish会在客户端和服务器之

间建立一条直接的连接 ,之后客户端的所有请求都直接发送给服务器,绕过varnish,不再由varnish

检查请求,直到连接断开。 


Request 

1、调用 pass 函数,从后端服务器调用数据。 

 

2、调用 pipe 函数,建立客户端和后端服务器之间的直接连接,从后端服务器调用数据。 

 

3、调用lookup函数,从缓存中查找应答数据并返回,如果查找不到,则调用pass函数从后端服务器

调用数据 。 



varnish vcl配置文件:


vcl_recv 接受请求

vcl_hash 缓存策略

vcl_fetch 不缓存

vcl_hit 命中

vcl_miss 未命中


if (req.request !="GET" && req.request != "HEAD" && req.request != "PUT" && req.request != "POST" && req.request !="TRACE" && req.request != "OPTIONS" && req.request != "DELETE") {
return (pipe);
}



#如果不是get和head,那就是post。post属于发送数据给服务器,需要服务器接受数据并处理,属于动态。

if (req.request != "GET" && req.request != "HEAD") {
return (pass);
}

#认证信息

if (req.http.Authorization || req.http.Cookie) {
return (pass);
}
return (lookup);


hash_data(req.url);
if (req.http.host) {
hash_data(req.http.host);
} else {
hash_data(server.ip);
}
return (hash);


#sub vcl_deliver 返回引擎,客户端提示是否命中

sub vcl_deliver {
    if (obj.hits > 0) {
       set resp.http.X-Cache = "Hit"; 
    } else {
       set resp.http.X-Cache = "Miss";
    }
}



缓存时间的计算方法


缺省的缓存时间计算方法如下:


. 先根椐max-age确定缓存时间


看返回头中的Cache-Control头中,有没有指定s-maxage或max-age信息,另外,如果后端是一个缓存服务器,它还会指定一个age头,表明已经缓存过的时间,这样需要减去age头指定的时间,计算出对应的缓存时间。


例1 只有max-age,没有age


CacheControl: max-age=86400


缓存时间:86400秒,即一天


例2 同时有max-age和age信息


CacheControl: max-age=86400

Age: 6400


缓存时间:86400 - 6400 = 80000秒



本文出自 “蚂蚁” 博客,请务必保留此出处http://215687833.blog.51cto.com/6724358/1913365

以上是关于Varnish 缓存的主要内容,如果未能解决你的问题,请参考以下文章

7.5 Varnish VCL的变量和应用片段

varnish实现缓存加速

varnish缓存代理

Varnish反向代理缓存服务器

varnish缓存代理

高性能HTTP加速器varnish实践