Receive—————— Pass \ Pipe
| |
| |
| Fetch —————
| ↑ |
| | |
Lookup ——— Miss |
| |
| ↓
Hit ———————————deliver
varnishd变量类型详解:
请求到达varnish,可以使用的VCL内置公用变量
req.backend # 指定对应的后端主机
req.request # 指定请求的类型:GET HEAD POST 等
req.http.header # 指定请求中的http头信息
req.url #指定请求的地址
req.proto #表示client请求的http协议版本
req.restarts #表示请求重启的次数,默认最大值为4
向后端主机请求时,可以使用的VCL内置的公用变量
beresp.request #指定请求的类型,例如GET 和HEAD等
beresp.url #指定请求地址
beresp.proto #指定client请求的http协议版本
beresp.http.header #指定请求中的http头信息
beresp.ttl #缓存的生存周期,也就是cache保留多长时间,单位是S
beresp.status #指定内容的请求代码,例如502,503等
从cache或后端主机获取内容后,可以使用的
obj.status #返回内容的请求状态代码,例如200,302,504等
obj.cacheable #返回内容是否可以缓存,也就是说,如果http返回的是200,203,300,301,302 404 或410等,并且有非0的生存周期,则可以缓存。
obj.valid #是否是有效的http应答
obj.response #返回内容的请求状态信息
obj.proto #返回内容的http协议版本
obj.ttl #返回内容的生存周期,也就是缓存时间,单位是s
obj.lastuse #返回上一次请求到现在的间隔时间,单位是s
返回给client的,可以使用的
resp.status #返回给client的http状态代码
resp.proto #返回给client的http协议版本
resp.http.header #返回给client的http头部信息
resp.response #返回给client的http状态信息
unset req.http.cookie #清除cookie缓存
default.vcl: #实例仅供参考
# This is a basic VCL configuration file for varnish. See the vcl(7)
# man page for details on VCL syntax and semantics.
#
# Default backend definition. Set this to point to your content
# server.
#
backend webserver1 {
.host = "127.0.0.1"; #定义web1的ip 和nginx的端口
.port = "8081";
}
backend webserver3 {
.host = "10.2.16.253"; #定义web1的ip 和nginx的端口
.port = "8081";
}
backend img {
.host = "10.2.16.253"; #定义图片服务器的ip和nginx端口
.port = "8090";
}
#backend webserver4 {
# .host = "10.2.16.254";
# .port = "8082";
#}
#
# Below is a commented-out copy of the default VCL logic. If you
# redefine any of these subroutines, the built-in logic will be
# appended to your code.
#
director webserver random { #定义一个director服务器组,由后端两台web来承担请求,用权值来分配请求几率;
{.backend = webserver1; .weight = 1;}
{.backend = webserver3; .weight = 1;}
}
acl purge {
#定义清除缓存规则,允许127.0.0.1和10.2.16.0 网段的ip通过PURGE方法清除缓存;"127.0.0.1";
"10.2.16.0"/24;
}
sub vcl_recv {
#Receive模块;
if (req.request == "PURGE") {
#当发送PURGE请求的客户端不在acl中设定的地址时,将返回405代码,提示“Not allowed.”if (!client.ip ~ purge) {
error 405 "Not allowed.";
}
elseif (req.url ~ "\. (php|cgi)($|\?)") { #当请求的URL以php或cgi结尾时,则不缓存,交给后端服务器处理。
return (pass);
}
else {
return (lookup);
}
}
if (req.url ~ "^/img") { #当URL中包括img时,将请求发送给img服务器,否则,发送给web1服务器。
set req.backend = img;
} else {
set req.backend = webserver1;
}
#if ((req.http.host ~"www.xxx.com")&&(req.restarts ==0)) {
# set req.backend = webserver;
#} elseif (req.restarts == 1) {
# set req.backend = webserver4;
#}
if (req.http.host ~"www.xxx.com") { #如果请求的URL是 "www.xxx.com",则将请求分发给服务器组webserver。
set req.backend = webserver;
}
#if (req.url ~ "^/p_w_picpaths") { #清除/p_w_picpaths目录下的所有缓存,如果访问的URL匹配这个规则,那么头信息中的cookie就会被删除。
# unset req.http.cookie;
# }
if (req.request != "GET" && req.request != "HEAD") #如果请求不是GET和HEAD,则缓存
{
return (pipe);
}
elseif (req.http.Authenticate || req.http.Authorization) {
return (pass);
}
return (lookup);
}
sub vcl_hit # Hit模块
{
if (req.request == "PURGE") { # 如果请求类型是PURGE方法,varnishd会将此请求的缓存周期设置为0,也就是使这个URL的缓存失效,从而达到刷新varnish缓存的目的。
set obj.ttl = 0s; #设置缓存周期为0
error 200 "Purged.";
}
if (!obj.cacheable)
{
return (pass);
}
if (obj.http.Vary)
{
unset obj.http.Vary;
}
}
sub vcl_miss #Miss模块
{
if (req.request == "PURGE") {
error 404 "Not in cache.";
}
}
sub vcl_hash {
#Hash模块set req.hash += req.url; #定义hash值,并且处理压缩内容
if (req.http.host) {
set req.hash += req.http.host;
} else {
set req.hash += server.ip;
}
if ( req.http.Accept-Encoding ){
if (req.url ~ "\.(jpg|jpeg|png|xsl|xml|pdf|ppt|doc|docx|chm|rar|zip|bmp|jpeg|swf|ico|mp3|mp4|rmvb|ogg|mov|avi|wmv|swf|txt|png|gif|jpg|css|js|html|htm)$") {
} else {
set req.hash += req.http.Accept-Encoding;
}
}
return (hash);
}
sub vcl_fetch #Fetch模块
{
if (!beresp.cacheable) {
return (pass);
}
if (beresp.http.Set-Cookie) {
return (pass);
}
if (beresp.status == 500 || beresp.status == 501 || beresp.status == 502 || beresp.status == 503 || beresp.status == 504 || beresp.status == 404)
#定义在什么状态下进入restart模式
{
return (restart);
}
if (beresp.http.Pragma ~ "no-cache" || beresp.http.Cache-Control ~ "no-cache" || beresp.http.Cache-Control ~ "private")
#定义不缓存内容含有哪些http头的请求
{
return (pass);
}
if (req.request == "GET" && req.url ~ "\.(css|js|html|htm)$") { #定义不同内容的缓存时间
set beresp.ttl = 300s;
}
if (req.request == "GET" && req.url ~ "\.(gif|jpg|jpeg|bmp|png|tiff|img)$") {
set beresp.ttl = 3600s;
}
if (req.request == "GET" && req.url ~ "\.(svg|swf|ico|mp3|mp4|wav|rmvb|avi|wmv)$") {
set beresp.ttl = 10d;
}
return (deliver);
}
sub vcl_deliver {
#Deliver模块if (obj.hits > 0) {
set resp.http.X-Cache = "HIT from www.xxx.com";
} else {
set resp.http.X-Cache = "MISS from www.xxx.com";
}
return (deliver);
}
# }
#if (beresp.http.Set-Cookie) {
# return (pass);
#}
# return (deliver);
#}
# sub vcl_error {
# set obj.http.Content-Type = "text/html; charset=utf-8";
# synthetic {"
# <?xml version="1.0" encoding="utf-8"?>
# <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
# "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
# <html>
# <head>
# <title>"} obj.status " " obj.response {"</title>
# </head>
# <body>
# <h1>Error "} obj.status " " obj.response {"</h1>
# <p>"} obj.response {"</p>
# <h3>Guru Meditation:</h3>
# <p>XID: "} req.xid {"</p>
# <hr>
# <address>
# <a href="http://www.varnish-cache.org/">Varnish cache server</a>
# </address>
# </body>
# </html>
# "};
# return (deliver);
# }