基于centos 6.5使用varnish实现网站动静分离

 更新时间:2014年11月29日 22:41:32   投稿:mdxy-dxy  
这篇文章主要介绍了基于centos6.5使用varnish实现网站动静分离,需要的朋友可以参考下

一、Varnish简介

Varnish是一款高性能、开源的反向代理服务器和缓存服务器,其开发者Poul-Henning Kamp是FreeBSD核心的开发人员之一。
Varnish主要运行两个进程:Management进程和Child进程(也叫Cache进程)。
Management进程主要实现应用新的配置、编译VCL、监控varnish、初始化varnish以及提供一个命令行接口等。Management进程会每隔几秒钟探测一下Child进程以判断其是否正常运行,如果在指定的时长内未得到Child进程的回应,Management将会重启此Child进程。

二、Varnish工作流程

wKiom1NsyzSwm0mkAADwry7okjs541.jpg
1)、varnish从客户端接收请求后,由vcl_recv状态引擎处理,不能识别的请求将会通过参数pipe交给vcl_pipe状态引擎,需要查找缓存的请求通过lookup参数将会交给vcl_hash状态引擎,无需缓存的数据通过参数pass将会交给 vcl_pass状态引擎;
2)、vcl_hash状态引擎在接收到请求后会从缓存中查找数据,查询结果有两种,一种是hit缓存命中,另一种是miss缓存未命中;
3)、vcl_hit状态引擎将命中的缓存数据通过参数deliver交给vcl_deliver状态引擎,vcl_deliver状态引擎将数据处理后,最终返回给客户端;
4)、vcl_miss状态引擎将未命中的结果参数fetch交给vcl_fetch状态引擎,vcl_fetch状态引擎将会从数据库中查找数据;
5)、vcl_fetch状态引擎将从数据库中查询到的结果,返回给vcl_deliver状态引擎;
6)、vcl_deliver状态引擎将结果返回给master进程,最终返回给客户端;

三、使用Varnish实现网站动静分离

实验环境,三台虚拟机
Linux:CentOS6.5
Varnish:varnish-3.0.4-1.el6.x86_64
Nginx:nginx-1.4.7
Varnish主机:两块网卡,外网IP 172.16.36.10,内网IP 192.168.0.10
Web服务器1:IP 192.168.0.20,用于作静态文件服务器
Web服务器2:IP 192.168.0.30,用于作动态程序服务器
前提说明:
varnish的配置文件为vcl后缀,位于/etc/varnish/目录,缓存通常用于提升响应速度,一般而言,可以缓存html静态页面、图片、js脚本、css样式表,因为动态脚本语言编写的页面需要使用脚本引擎处理,因此没有缓存的必要性;nginx本身就有缓存及反向代理功能,完全可以实现web服务的动静分离,不过以缓存功能作对比,varnish的缓存显然比nginx更专业,所以要作缓存服务器,可以试试varnish,本次操作将以实验性的目的,使用varnish实现web服务动静分离;
1、安装Varnish
# rpm -ivh varnish-3.0.4-1.el6.x86_64.rpm varnish-docs-3.0.4-1.el6.x86_64.rpm varnish-libs-3.0.4-1.el6.x86_64.rpm
2、配置varnish
1)、编辑varnish脚本的配置文件/etc/sysconfig/varnish,将varnish监听的端口修改为80;
wKioL1Ns09OQYb43AAGMXnH0NSo021.jpg
2)、新建文件/etc/varnish/web.vcl,编辑varnish缓存规则;

#定义后端服务器
backend web1 {
  .host="192.168.0.20";
  .port="80";
}
backend web2 {
  .host="192.168.0.30";
  .port="80";
}
#只允许本机使用purgers请求方法清除缓存
acl purgers {
  "127.0.0.1";
  "172.16.0.0"/16;
}
sub vcl_recv {
 if(req.request=="PURGE"){
   if(!client.ip~purgers) {
     error 405 "Mothod not allow";
   }
  }
#静态资源交给web1服务器
  if(req.url ~ "\.(html|htm|shtml|css|js|jpg|png|gif|jpeg)"){
   set req.backend=web1;
  }
#php页面交给web2服务器,并跳过缓存
  if(req.url ~ "\.php") {
   set req.backend=web2;
   return(pass);
  }
  return(lookup);
}
#将命中的缓存清除
sub vcl_hit {
 if (req.request == "PURGE") {
  purge;
  error 200 "Purged OK";
 }
}
#如果请求清除的资源不在缓存列表中,返回404状态
sub vcl_miss {
 if (req.request == "PURGE") {
  purge;
  error 404 "Not in cache";
 }
}
#如果请求清除的资源是一个不可缓存的资源,返回502状态
sub vcl_pass {
 if (req.request == "PURGE") {
  error 502 "Purged on a passed object.";
 }
}
#缓存对象存活时间
sub vcl_fetch {
  if(req.url ~ "\.(html|htm|shtml|css|js|jpg|png|gif|jpeg)"){
   set beresp.ttl=7200s;
  }
}
#将结果返回给客户端并在响应头部添加两字段,显示命中与否,并显示后端响应的web服务器
sub vcl_deliver {
  if(obj.hits > 0) {
   set resp.http.X-Cache="HIT from" + " " + server.ip;
  }else{
   set resp.http.X-Cache="MISS";
  }
  set resp.http.Backend-IP=req.backend;
}

3)、将配置加载至varnish;

3.1)、连接varnish;
wKiom1Ns-RPiWqFpAAE5Lq1QxNw477.jpg
3.2)、加载配置;
wKioL1Ns-U2Tfe__AABDQlpXD5M557.jpg
3.3)、使用配置;
wKiom1Ns-Y7Bsr-oAABmt_0ifnw122.jpg
4)、配置两台web服务器,分别安装nginx与php;
192.168.0.20服务器,新建两页面,index.html与index.php,两页面请求输出结果如下:
wKioL1Ns-c_QoTqUAACmmAj5sXg638.jpg
192.168.0.30服务器,新建两页面,index.html与index.php,两页面请求输出结果如下:
wKiom1Ns-gyS9VN5AACr_oSdPkw052.jpg
5)、测试结果,打开地址:172.16.36.10;

当我们请求html页面时,无论我们怎么刷新请求,缓存总是命中,并显示HIT,并且后端服务器一直是,web1(192.168.0.20);

wKiom1Ns-i3wGmZxAAKtGq5-1Rk960.jpg

当我们请求php页面时,我们不让他缓存,那么缓存也就永远不会命中,显示MISS,并且后端服务器一直是,web2(192.168.0.30);

wKioL1Ns-hbjfop6AAJ0XCavf9g476.jpg

6)、清除缓存;

wKioL1Ns-kLSZ2ItAAHsEtVY9tA214.jpg
整个配置完成,varnish实现了动静分离;

相关文章

  • ubuntu16.0.4 设置固定ip地址的方法

    ubuntu16.0.4 设置固定ip地址的方法

    这篇文章主要介绍了ubuntu16.0.4 设置固定ip地址的方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-07-07
  • Easypanel免费的VPS主机面板 可跨平台Linux和Windows

    Easypanel免费的VPS主机面板 可跨平台Linux和Windows

    Easypanel是一款免费的功能强大集开通虚拟主机,ftp空间,数据库等功能为一体的主机控制面板,具备跨平台(windows,linux),安全稳定、操作简便等特点,感兴趣的小伙伴们可以关注一下
    2017-07-07
  • Ubuntu 18.04 Server 设置静态IP 的方法

    Ubuntu 18.04 Server 设置静态IP 的方法

    Netplan是Ubuntu 17.10中引入的一种新的命令行网络配置实用程序,用于在Ubuntu系统中轻松管理和配置网络设置。这篇文章主要介绍了Ubuntu 18.04 Server 设置静态IP 的方法,需要的朋友可以参考下
    2018-11-11
  • Linux内核设备驱动地址映射笔记整理

    Linux内核设备驱动地址映射笔记整理

    今天小编就为大家分享一篇关于Linux内核设备驱动地址映射笔记整理,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • apache启动报错:httpd: apr_sockaddr_info_get() failed

    apache启动报错:httpd: apr_sockaddr_info_get() failed

    httpd: Could not reliably determine the server's fully qualified domain name, using 127.0.0.1 for ServerName
    2013-02-02
  • Linux实现科学上网

    Linux实现科学上网

    本文给大家介绍的是Linux下使用plink ssh + privoxy 实现局域网共享代理,非常的全面细致,这里推荐给大家。
    2015-03-03
  • Linux进程管理工具supervisor安装配置教程

    Linux进程管理工具supervisor安装配置教程

    这篇文章主要介绍了Linux进程管理工具supervisor安装配置教程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-05-05
  • Linux配置远程SSH无密码登录

    Linux配置远程SSH无密码登录

    这篇文章主要为大家详细介绍了Linux配置远程SSH无密码登录的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • 火山互联linux VPS配置方法

    火山互联linux VPS配置方法

    火山互联推出的免费VPS...拿来学习下还是不错的.申请过几次Liunx系统的.由于不是很熟悉.几次都没能配置好.下面介绍一下.前几天又申请了一个.
    2009-12-12
  • CentOS7连接XShell与网络配置的方法

    CentOS7连接XShell与网络配置的方法

    这篇文章主要介绍了如何使用CentOS7连接XShell与网络配置的方法,可以更好的帮助大家工作和学习,感兴趣的小伙伴可以了解下
    2020-05-05

最新评论