博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
教你搭--高性能缓存服务器varnish
阅读量:7043 次
发布时间:2019-06-28

本文共 3004 字,大约阅读时间需要 10 分钟。

Varnish是一款高性能的、开源的反向代理服务器和缓存服务器。计算机系统的内存除了主存外,还有CPU的L1、L2,甚至L3级别的缓存。Varnish的设计架构就是利用操作系统的缓存机制处理访问

教你搭--高性能缓存服务器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
<h1> server AA!!! </h1>

service httpd start

service firewalld stop

setenforce 0

验证测试:

真机: //访问varnishd服务器的地址,能够访问到第一台服务器内容
教你搭--高性能缓存服务器varnish

varnishlog //实时滚动日志,当页面刷新的时候日志会记录

教你搭--高性能缓存服务器varnish
tail –f /var/log/httpd/access_log //在业务服务器端查看日志信息,可以看到访问的是代理端
地址
教你搭--高性能缓存服务器varnish

---------------------------------配置多服务器负载---------------------------

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
<h1> server BB!!! </h1>

service httpd start

service firewalld stop

setenforce 0

验证:

//刷新测试就可以了看到轮询的效果了
教你搭--高性能缓存服务器varnish
教你搭--高性能缓存服务器varnish

停止一台服务器WEB1,调度器并不感知。

教你搭--高性能缓存服务器varnish
教你搭--高性能缓存服务器varnish

以下配置健康检查----在每台业务服务器配置下接着新增

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

浏览器测试,并关闭一台业务服务器2再测试。注意客户端浏览器缓存问题。不会再跳转关闭服务器内容了。

教你搭--高性能缓存服务器varnish

转载于:https://blog.51cto.com/13572519/2090524

你可能感兴趣的文章
Mac Terminal 设置ls 默认带有颜色显示
查看>>
java中的匿名内部类总结
查看>>
nginx 代理多个tomcat缓存
查看>>
用浏览器访问网址时,请求头(request header)是根据什么生成的?
查看>>
Webix学习笔记-创建一个基本应用程序-06-和服务器交互之Update
查看>>
maven 使用filter动态处理资源文件变量
查看>>
linux 环境下使用信号量实现司机售票员进程同步,线程同步问题
查看>>
记录otter遇到问题
查看>>
dubbo服务暴露过程源码分析
查看>>
使用maven插件maven-android-plugin构建android程序
查看>>
DefaultHttpClient 使用GZIPInputStream解压缩
查看>>
Ansible随机数
查看>>
最简单的将手机号显示为匿名
查看>>
java高新技术<四>--类加载器、动态代理技术的深入讲解与应用
查看>>
NDK开发基础①使用Android Studio编写NDK
查看>>
Mesos + Docker Tutorial: How to Build Your Own Fra
查看>>
centos下安装五笔
查看>>
spring eureka-server配置
查看>>
ul动态生成li(JavaScript写)
查看>>
android自定义TabWidget
查看>>