Varnish高性能HTTP加速服务器教程

2024-02-19 08:38

本文主要是介绍Varnish高性能HTTP加速服务器教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

主机环境:
  • rhel6.5 selinux and iptables disabled
实验主机:
主机名IP服务
server1172.25.254.1varnish
server2172.25.254.2apache
server3172.25.254.3apache
Varnish工作原理图

这里写图片描述

VCL (Varnish Configuration Language)处理流程图

这里写图片描述

处理过程大致分为如下几个步骤:
  • Receive 状态,也就是请求处理的入口状态,根据 VCL 规则判断该请求应该是 Pass 或 Pipe,或者进入 Lookup(本地查询)。
  • Lookup 状态,进入此状态后,会在 hash 表中查找数据,若找到,则进入 Hit 状态,否则进入 miss 状态。
  • Pass 状态,在此状态下,会进入后端请求,即进入 fetch 状态。
  • Fetch 状态,在 Fetch 状态下,对请求进行后端的获取,发送请求,获得数据,并进行本地的存储。
  • Deliver 状态, 将获取到的数据发送给客户端,然后完成本次请求。
设计思想:firefox -> hosts/dns -> varnish -> httpd
varnish–server1
  • 安装
    • http://varnish-cache.org/releases/install_redhat.html#install-redhat
[root@server1 ~]# yum install -y varnish-3.0.5-1.el6.x86_64.rpm  varnish-libs-3.0.5-1.el6.x86_64.rpm 
  • 配置 varnish 服务端口
[root@server1 ~]# vim /etc/sysconfig/varnishVARNISH_LISTEN_PORT=80
  • 配置一个后端服务器
[root@server1 ~]# vim /etc/varnish/default.vcl
backend default {.host = "172.25.254.2";.port = "80";
}
  • 查看缓存命中情况
[root@server1 ~]# vim /etc/varnish/default.vcl
sub vcl_deliver {if (obj.hits > 0) {set resp.http.X-Cache = "HIT from test cache";}else {set resp.http.X-Cache = "MISS from test cache";}return (deliver);}
  • 开启服务
[root@server1 ~]# /etc/init.d/varnish start
apache–server2
  • 安装apache
[root@server2 ~]# yum install -y httpd
  • 编写前端文件
[root@server2 ~]# cat /var/www/html/index.html
<h1>Welcome to www.westos.org !!</h1>
  • 开启服务
[root@server2 ~]# /etc/init.d/httpd start
物理机测试
  • 添加解析
 [root@fundation20 Desktop]# cat /etc/hosts
172.25.254.1 server1 www.westos.org 
  • 测试
##未命中
[root@fundation20 Desktop]# curl -I www.westos.org
HTTP/1.1 200 OK
Server: Apache/2.2.15 (Red Hat)
Last-Modified: Tue, 13 Feb 2018 00:46:57 GMT
ETag: "20331-26-5650d54eefd0e"
Content-Type: text/html; charset=UTF-8
Content-Length: 38
Accept-Ranges: bytes
Date: Tue, 13 Feb 2018 02:09:16 GMT
X-Varnish: 120543320
Age: 0
Via: 1.1 varnish
Connection: keep-alive
X-Cache: MISS from test cache
##命中
[root@fundation20 Desktop]# curl -I www.westos.org
HTTP/1.1 200 OK
Server: Apache/2.2.15 (Red Hat)
Last-Modified: Tue, 13 Feb 2018 00:46:57 GMT
ETag: "20331-26-5650d54eefd0e"
Content-Type: text/html; charset=UTF-8
Content-Length: 38
Accept-Ranges: bytes
Date: Tue, 13 Feb 2018 02:09:18 GMT
X-Varnish: 120543321 120543320
Age: 2
Via: 1.1 varnish
Connection: keep-alive
X-Cache: HIT from test cache
通过 varnishadm 手动清除缓存
 [root@server1 ~]# varnishadm ban.url .*$           #清除所有[root@server1 ~]# varnishadm ban.url /index.html   #清除 index.html 页面缓存[root@server1 ~]# varnishadm ban.url /admin/$      #清除 admin 目录缓存

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

  • varnish–server1
[root@server1 ~]# vim /etc/varnish/default.vcl
#配置两个后端服务器
backend web1 {.host = "172.25.254.2";.port = "80";
}
backend web2 {.host = "172.25.254.3";.port = "80";
}
#当访问 www.westos.org 或 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;} elsif (req.http.host ~ "^bbs.westos.org") {set req.backend = web2;} else {error 404 "westos cache";}}##重启服务[root@server1 ~]# /etc/init.d/varnish restartStopping Varnish Cache:                                    [  OK  ]Starting Varnish Cache:                                    [  OK  ]
  • apache–server2
 [root@server2 ~]# cat /var/www/html/index.html 
<h1>Welcome to www.westos.org from server2 !!</h1>[root@server2 ~]# /etc/init.d/httpd  restart
  • apache–server3
 [root@server3 ~]# yum install -y httpd[root@server3 ~]# cat /var/www/html/index.html
<h1>Welcome to bbs.westos.org from server3 !!</h2>[root@server3 ~]# /etc/init.d/httpd start
物理机测试
  • 添加解析
 [root@fundation20 Desktop]# cat /etc/hosts
172.25.254.1 server1 www.westos.org westos.org bbs.westos.org
  • 浏览器测试
    这里写图片描述
    这里写图片描述
    这里写图片描述
    这里写图片描述

负载均衡

  • varnish–server1
[root@server1 ~]# vim /etc/varnish/default.vcl
#配置两个后端服务器
backend web1 {.host = "172.25.254.2";.port = "80";
}
backend web2 {.host = "172.25.254.3";.port = "80";
}
##把两个后端聚合为一个组,并检测后端健康状况
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";}}[root@server1 ~]# /etc/init.d/varnish restart
Stopping Varnish Cache:                                    [  OK  ]
Starting Varnish Cache:                                    [  OK  ]
  • apache–server2
[root@server2 ~]# cat /var/www/html/index.html 
<h1>Welcome to www.westos.org from server2 !!</h1>[root@server2 ~]# /etc/init.d/httpd restart
  • apache–server3
#搭建虚拟主机,保留原/var/www/html/index.html
[root@server3 ~]# vim /etc/httpd/conf/httpd.conf #打开虚拟主机服务
NameVirtualHost *:80   #去掉注释##添加到最后
<VirtualHost *:80>DocumentRoot  /var/www/htmlServerName    bbs.westos.org
</VirtualHost><VirtualHost *:80>DocumentRoot  /wwwServerName    www.westos.org
</VirtualHost>[root@server3 ~]# mkdir /www
[root@server3 ~]# vim /www/index.html
<h1>Welcome to www.westos.org from server3 !!</h1>[root@server3 ~]# /etc/init.d/httpd restart##添加本地解析
[root@server3 ~]# cat /etc/hosts
172.25.254.3 server3 www.westos.org bbs.westos.org ##测试虚拟机主机
[root@server3 ~]# curl www.westos.org
<h1>Welcome to www.westos.org from server3 !!</h1>
[root@server3 ~]# curl bbs.westos.org
<h1>Welcome to bbs.westos.org from server3 !!</h2>
物理机测试:
  • 查看解析
[root@fundation20 Desktop]# cat /etc/hosts
172.25.254.1 server1 www.westos.org westos.org bbs.westos.org
  • 浏览器测试
    这里写图片描述
    这里写图片描述
  • 终端测试
[root@fundation20 Desktop]# for i in {1..6}; do curl www.westos.org ;done
<h1>Welcome to www.westos.org from server2 !!</h1>
<h1>Welcome to www.westos.org from server3 !!</h1>
<h1>Welcome to www.westos.org from server2 !!</h1>
<h1>Welcome to www.westos.org from server3 !!</h1>
<h1>Welcome to www.westos.org from server2 !!</h1>
<h1>Welcome to www.westos.org from server3 !!</h1>

这篇关于Varnish高性能HTTP加速服务器教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/724122

相关文章

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

如何为Yarn配置国内源的详细教程

《如何为Yarn配置国内源的详细教程》在使用Yarn进行项目开发时,由于网络原因,直接使用官方源可能会导致下载速度慢或连接失败,配置国内源可以显著提高包的下载速度和稳定性,本文将详细介绍如何为Yarn... 目录一、查询当前使用的镜像源二、设置国内源1. 设置为淘宝镜像源2. 设置为其他国内源三、还原为官方

Maven的使用和配置国内源的保姆级教程

《Maven的使用和配置国内源的保姆级教程》Maven是⼀个项目管理工具,基于POM(ProjectObjectModel,项目对象模型)的概念,Maven可以通过一小段描述信息来管理项目的构建,报告... 目录1. 什么是Maven?2.创建⼀个Maven项目3.Maven 核心功能4.使用Maven H

springboot上传zip包并解压至服务器nginx目录方式

《springboot上传zip包并解压至服务器nginx目录方式》:本文主要介绍springboot上传zip包并解压至服务器nginx目录方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录springboot上传zip包并解压至服务器nginx目录1.首先需要引入zip相关jar包2.然

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

Python虚拟环境终极(含PyCharm的使用教程)

《Python虚拟环境终极(含PyCharm的使用教程)》:本文主要介绍Python虚拟环境终极(含PyCharm的使用教程),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录一、为什么需要虚拟环境?二、虚拟环境创建方式对比三、命令行创建虚拟环境(venv)3.1 基础命令3

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.