Red Hat Linux 7 下Varnish简单搭建
Red Hat Linux 7 下Varnish简单搭建
主机环境 rhel6 selinux and iptables disabled
实验主机 172.25.254.2 varnish
172.25.254.3 apache
172.25.254.4 apache
首先得到这两个包
varnish-3.0.5-1.el6.x86_64.rpm varnish-libs-3.0.5-1.el6.x86_64.rpm
安装
yum install varnish-* -y
###配置一个后端服务器
Vim /etc/varnish/default.vcl
.host = "172.25.254.3";
.port = "80";
}
这里写的3为后端,那先给它创建一个首页,方便测试
###配置 varnish 服务端口
VARNISH_LISTEN_PORT=80
/etc/init.d/varnish restart
为了测试显示更加清晰在vcl中添加如下代码
sub vcl_deliver {
if (obj.hits > 0) {
set resp.http.X-Cache = "HIT from xp1 cache";
}
else {
set resp.http.X-Cache = "MISS from xp1 cache";
}
return (deliver);
}
/etc/init.d/varnish restart
###测试缓存命中
在4上
[root@vm4 ~]# curl 172.25.254.2
haha-vm3
age 后面是时间,默认是120妙
HIT就代表命中 MISS就代表去后端查询去了
###通过 varnishadm 手动清除缓存
# varnishadm ban.url .*$
#清除所有
# varnishadm ban.url /index.html
#清除 index.html 页面缓存
# varnishadm ban.url /admin/$
#清除 admin 目录缓存
###定义多个不同域名站点的后端服务器
backend xp1 {
.host = "172.25.39.3";
.port = "80";
}
backend xp2 {
.host = "172.25.39.4";
.port = "80";
}
#当访问 www.bkjia.org 域名时从 xp1 上取数据,访问 bbs.bkjia.org 域名时到 xp2 取数据,访问其他页面报错。
sub vcl_recv {
if (req.http.host ~ "^(www.)?bkjia.com") {
set req.http.host = "www.bkjia.com";
set req.backend = xp1;
} elsif (req.http.host ~ "^bbs.bkjia.com") {
set req.backend = xp2;
} else {error 404 "bkjia cache";
}
}
###定义负载均衡
director lb round-robin {
{ .backend = xp1;}
{.backend = xp2;}
}
上面采用rr算法,还有其他算法如hash,fallback,random等
sub vcl_recv {
if (req.http.host ~ "^(www.)?bkjia.com") {
set req.http.host = "www.bkjia.com";
set req.backend = lb;
return (pass); #为了测试方便,不进行缓存。
} elsif (req.http.host ~ "^bbs.bkjia.com") {
set req.backend = xp2;
} else {
error 404 "bkjia cache";
}
}
测试效果
###varnish cdn 推送平台
http://code.google.com/p/varnish-php-bansys/
#需要安装 php 支持
unzip bansys.zip -d /var/www/html
vim /var/www/html/bansys/config.php #只保留如下设置,其余注释掉 <?php
$var_group1 = array(
'host' => array('172.25.254.2'),
'port' => '6082',
);
//varnish 群组定义
//对主机列表进行绑定
$VAR_CLUSTER = array(
'www.bkjia.com' => $var_group1,
);
//varnish 版本//2.x 和 3.x 推送命令不一样
$VAR_VERSION = "3";
?>
bansys 有两种工作模式,分别是:telnet 和 http 模式。
telnet 模式需要关闭 varnish 服务管理端口的验证,注释掉/etc/sysconfig/varnish 文件中的“-S $
{VARNISH_SECRET_FILE}”这行,重启 varnish 服务即可。
如果是http模式需要做如下设置:
vim /etc/varnish/default.vcl
acl bkjia {
#设置访问控制
"127.0.0.1";
"172.25.254.0"/24;
}
sub vcl_recv {
if (req.request == "BAN") {
if (!client.ip ~ bkjia) {
error 405 "Not allowed.";
}
ban("req.url ~ " + req.url);
error 200 "ban added";
}
}
然后在浏览器中就可以查看了
缓存服务器Varnish概念篇
缓存服务器Varnish概念篇
Varnish Cache 的架构笔记
CentOS 5.8下Varnish-2.1.5的安装配置
RedHat脚本改用CentOS源更新安装Nginx、PHP 5.3、Varnish
利用Varnish构建Cache服务器笔记
缓存服务Varnish安装配置
Varnish 编译安装所需准备
Linux下Varnish缓存的配置优化
Varnish 的详细介绍:请点这里
Varnish 的下载地址:请点这里
本文永久更新链接地址:
评论暂时关闭