varnish

主机环境: rhel6 selinux and iptables disabled

实验主机: 172.25.45.250

Varnish    172.25.45.11

Apache    172.25.45.12

Apache    172.25.45.13

处理过程大致分为如下几个步骤:

(1)Receive 状态,也就是请求处理的入口状态,根据 VCL 规则判断该请求应该是 Pass

Pipe,或者进入 Lookup(本地查询)

(2)Lookup 状态,进入此状态后,会在 hash 表中查找数据,若找到,则进入 Hit 状态,否则进

miss 状态。

(3)Pass 状态,在此状态下,会进入后端请求,即进入 fetch 状态。

(4)Fetch 状态,Fetch 状态下,对请求进行后端的获取,发送请求,获得数据,并进行本地

的存储。

(5)Deliver 状态, 将获取到的数据发送给客户端,然后完成本次请求

 

 

1. 安装

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

yum localinstall -y varnish-3.0.3-1.el6.x86_64.rpm varnish-libs-3.0.3-1.el6.x86_64.rpm

2. 配置

# vi /etc/varnish/default.vcl

###配置一个后端服务器

backend web1 {

.host = "172.25.45.12";

.port = "80";

}

###配置 varnish 服务端口

# vi /etc/sysconfig/varnish

VARNISH_LISTEN_PORT=80

# service varnish start

###查看缓存命中情况

sub vcl_deliver {

if (obj.hits > 0) {

set resp.http.X-Cache = "HIT from westos cache";

}

else {

set resp.http.X-Cache = "MISS from westos cache";

}

return (deliver);

}

# service varnish reload

 

###测试缓存命中

 

varnish_第1张图片 

 

 

varnish_第2张图片 

 

 

 

 

###通过 varnishadm 手动清除缓存

# varnishadm ban.url .*$             #清除所有

# varnishadm ban.url /index.html    #清除 index.html 页面缓存

# varnishadm ban.url /admin/$      #清除 admin 目录缓存

 

###定义多个不同域名站点的后端服务器

backend web1 {

.host = "172.25.45.12";

.port = "80";

}

backend web2 {

.host = "172.25.45.13";

.port = "80";

}

 

#当访问 www.westos.org 域名时从 web1 上取数据,访问 bbs.westos.org 域名时到 web2 取数据,

访问其他页面报错。

sub vcl_recv {

if (req.http.host ~ "^(www.)?westos.org") {

set req.http.host = "www.westos.org";

set req.backend = web1;

return (pass);

} elsif (req.http.host ~ "^bbs.westos.org") {

set req.backend = web2;

} else {error 404 "westos cache";

}

}

# service varnish reload

 

###定义负载均衡

director lb round-robin {

{  .backend = web1; }

{  .backend = web2; }

}

#把多个后端聚合为一个组,并检测后端健康状况

 

 

sub vcl_recv {

if (req.http.host ~ "^(www.)?westos.org") {

set req.http.host = "www.westos.org";

set req.backend = lb;

return (pass);

#为了测试方便,不进行缓存。

} elsif (req.http.host ~ "^bbs.westos.org") {

set req.backend = web2;

} else {

error 404 "westos cache";

}

}

# service varnish reload

 

###varnish cdn 推送平台

http://code.google.com/p/varnish-php-bansys/

 

#需要安装 php 支持

# unzip bansys.zip -d /var/www/html

# vi /var/www/html/bansys/config.php

#只保留如下设置,其余注释掉

varnish_第3张图片 

 

#bansys 有两种工作模式,分别是:telnet http 模式。

#telnet 模式需要关闭 varnish 服务管理端口的验证,注释掉/etc/sysconfig/varnish 文件中的“-S $

{VARNISH_SECRET_FILE}”这行,重启 varnish 服务即可。

#如果是 http 模式需要对 varnish 做以下设置:

# vi /etc/varnish/default.vcl

acl westos {

#设置访问控制

"127.0.0.1";

"172.25.45.0"/24;

}

sub vcl_recv {

if (req.request == "BAN") {

if (!client.ip ~ westos) {

error 405 "Not allowed.";

}

ban("req.url ~ " + req.url);

error 200 "ban added";

}

}

# service varnish reload

varnish_第4张图片