Varnish是一款高性能的、开源的反向代理服务器和缓存服务器。计算机系统的内存除了主存外,还有CPU的L1、L2,甚至L3级别的缓存。Varnish的设计架构就是利用操作系统的缓存机制处理访问
实验拓扑:
Varnish服务器: 192.168.80.101
WEB服务器1: 192.168.80.102
WEB服务器2: 192.168.80.103
Varnish服务器配置:
yum install -y \
libtool \
ncourses-devel \
pcre-devel \
libedit-devel \
libxslt \
groff \
pkgconfig \
ncurses-devel \
python-*
rpm -ivh /root/libedit-devel-3.0-12.20121213cvs.el7.x86_64.rpm
rpm -ivh /root/python-docutils-0.11-0.2.20130715svn7687.el7.noarch.rpm
tar xzvf varnish-5.2.1.tgz -C /opt
cd /opt/varnish-5.2.1
sh autogen.sh //检查环境
echo $? //是0就没问题
./configure \
--prefix=/usr/local/varnish \
--enable-debugging-symbols \
--enable-developer-warnings
make && make install
cd /usr/local/varnish/
ln -s /usr/local/varnish/sbin/varnishd /usr/sbin/
ln -s /usr/local/varnish/bin/* /usr/local/bin/
cp /usr/local/varnish/share/doc/varnish/example.vcl /usr/local/varnish/default.vcl
vi /usr/local/varnish/default.vcl //修改主机和端口号为第一台业务服务器
backend default {
.host = "192.168.80.102"; //第一台web服务器的ip地址
.port = "80";
}
varnishd -f /usr/local/varnish/default.vcl -a 0.0.0.0:80 //启动varnishd
netstat -anpt | grep varnishd //监听在80端口上
service firewalld stop
setenforce 0
WEB服务器1配置:
yum install -y httpd
vi /var/www/html/index.html
server AA!!!
service httpd start
service firewalld stop
setenforce 0
验证测试:
真机:http://192.168.80.101/ //访问varnishd服务器的地址,能够访问到第一台服务器内容
varnishlog //实时滚动日志,当页面刷新的时候日志会记录
tail –f /var/log/httpd/access_log //在业务服务器端查看日志信息,可以看到访问的是代理端
地址
---------------------------------配置多服务器负载---------------------------
Varnish服务器配置:
vi /usr/local/varnish/default.vcl
vcl 4.0;
import directors; //新增一行,导入一个directors
-----以下增加业务服务器节点-----
backend web1 {
.host = "192.168.80.102";
.port = "80";
}
backend web2 {
.host = "192.168.80.103";
.port = "80";
}
-----接着以上代码接着定义调度算法及指定流量转发----
sub vcl_init {
new bar = directors.round_robin(); //random(随机) round_robin dns
bar.add_backend(web1);
bar.add_backend(web2);
}
sub vcl_recv {
set req.backend_hint = bar.backend(); //流量转发给所有结点 注意括号
}
varnishd -C -f /usr/local/varnish/default.vcl > /dev/null //检查配置文件是否有错误
pkill varnishd
varnishd -f /usr/local/varnish/default.vcl
netstat -anpt | grep varnishd
WEB服务器2配置:
yum install -y httpd
vi /var/www/html/index.html
server BB!!!
service httpd start
service firewalld stop
setenforce 0
验证:
http://192.168.80.101/ //刷新测试就可以了看到轮询的效果了
以下配置健康检查----在每台业务服务器配置下接着新增
web1配置
backend web1 {
.host = "192.168.80.102";
.port = "80"; //下面新增
.probe = {
.url = "/";
.interval = 5s;
.timeout = 1s;
.window = 5;
.threshold = 3; //3次检查没有问题才认为健康
}
}
---web2配置相同----
backend web2 {
.host = "192.168.80.103";
.port = "80";
.probe = {
.url = "/";
.interval = 5s;
.timeout = 1s;
.window = 5;
.threshold = 3;
}
}
varnishd -C -f /usr/local/varnish/default.vcl > /dev/null
pkill varnishd
varnishd -f /usr/local/varnish/default.vcl
netstat -anpt | grep varnishd