Varnish基础配置实现动静分离web站点

由于一个web站点的程序的访问具有局部性特征:时间上的局部性:一个数据被访问过之后,可能很快会被再次访问到;空间局部性:一个数据被访问时,其周边的数据也有可能被访问到;varnish可将这部分数据缓存下来.
缓存的数据存在被访问较频繁的数据可以称其为热区:缓存同样存在局部性;时效性:如果缓存空间耗尽:则采用LRU,最近最少使用算法;将过期的缓存清理掉

varnish的基本工作原理:

Varnish通过类似于HTPP反向代理的方式将可以用来缓存的数据缓存下来直接响应给客户端的缓存数据,如果缓存中
没有相应的数据,它将会把请求指向后端机器,获取响应的数据进行响应客户端。
当varnish有缓存的时候响应通常只需要极短的时间,比直接访问后端机器通常要快几个量级,所以要尽可能的将可缓存的页面缓存到varnish中。


varnish工作模式图:

  

varnish的处理机制图:

哪些数据可以缓存或是不可缓存:1.尽量将站点公共的数据缓存下来;2.用排除用户的私有数据.

配置一个wordperss站点使用varnish缓存服务器并做动静分离

基础拓扑图:

varnish的配置(基于cenots7,整个配置过程应避免iptables和selinux的影响):
ntpdata 172.16.0.1  同步时间

安装varnish程序:

yum install varnish

编辑varnish的主配置文件:

vim /etc/varnish/varnish.params
    添加最后一行:
    DAEMON_OPTS="-p thread_pools=3 -p thread_pool_min=5 -p thread_pool_max=1000 -p thread_pool_timeout=300"

启动varnish程序:

systemctl restart varnish

编辑varnish的vcl配置文件:

vim /etc/varnish/default.vcl

作出如下基础配置:

vcl 4.0;

# Default backend definition. Set this to point to your content server.
backend default {      #定义后端动态主机(apm)
    .host = "192.168.5.109"; 
    .port = "80";
}
backend nginxsrvs {    #定义后端静态主机(nignx)
  .host = "192.168.5.108";
   .port = "80";
}

sub vcl_recv {
    # Happens before we check if we have this in cache already.
    #
    # Typically you clean up the request here, removing cookies you don‘t need,
    # rewriting the request, etc.
    if (req.method == "PURGE") {       #指明何时可以用PURGE请求裁剪缓存数据
         return(purge);
}
    if (req.url ~ "(?i)^/(login|admin)") {   #指定一些私用数据不查找缓存数据
                                        return(pass);
                                }
    if (req.url ~ "(?i)\.(html|htm|css|svg|js|jpg|jpeg|png|gif|pdf)") { #指定的内容由静态服务器响应,其他的为动态服务器响应
         set req.backend_hint = nginxsrvs;   #指明响应的后端主机
    } else {
         set req.backend_hint =   default;   #指明响应的前端主机
    }

}

sub vcl_purge {
        return (synth(200,"Purged"));   #指明可以执行的PURGE操作
}

sub vcl_deliver {                                                 
    if (obj.hits>0) {       #可以用来做缓存是否被命中,obj.hits用于统计缓存命中的次数                               
        set resp.http.X-Cache = "HIT via " + server.ip;           
    } else {                                                      
        set resp.http.X-Cache = "Miss via " + server.ip;          
}

将default.vcl文件编译加载至varnish程序:

varnishadm -S secret
     进入varnish配置的cli界面,执行编译加载:
     vcl.load test1 default.vcl   #编译
     vcl.use test1                 #加载
     quit                          #退出

配置apm动态服务器:

yum install httpd
mkdir -p /apps/data (需要考虑权限)

将wordpress的源码文件cp至目录下

编辑httpd的站点配置文件

vim /etc/httpd/conf.d/wordpress.conf

<VirtualHost *:80>
    DirectoryIndex index.php index.html
    ServerName www.abc.com
    DocumentRoot /apps/data/wordpress
    <Directory "/apps/data/">
            Options FollowSymLinks
            AllowOverride None
            Require all granted
    </Directory>
</VirtualHost>

启动httpd程序:

systemctl  restart httpd

配置nfs服务用于共享网站文件

yum install nfs-utils
vim /etc/exports
/apps/data *(rw,all_squash,anonuid=48)

配置nginx静态服务器:

yum install nginx   #这里要用到nginx官方提供的yum源

配置/etc/nginx/conf.d/default.conf文件,作出如下修改

vim /etc/nginx/conf.d/default.conf
location / {
    root   /apps/data/wordpress;   #指明web程序的路径
    index  index.html index.htm;
}

启动nginx服务程序

systemctl restart nginx

更改hosts文件即可做访问测试.


varnish的基础配置实现已完成.

时间: 2024-11-03 01:26:58

Varnish基础配置实现动静分离web站点的相关文章

配置Tomcat管理迪士尼网站平台开发和配置虚拟机以及搭建web站点

1.用记迪士尼网站平台开发 haozbbs.comQ1446595067 事本打开Tomcat的目录下的conf文件中的"tomcat-user.xml". 2.写入以下代码 <?xml version=1.0 encoding="UTF-8"?> <tomcat-users> <role rolename="manager-gui"/> <user username="ab123"p

Nginx+tomcat7的负载均衡和动静分离配置

简介: 所谓动静分离就是通过nginx(或apache等)来处理用户端请求的图片.html等静态的文件,tomcat(或weblogic)处理jsp.do等动态文件,从而达到动静页面访问时通过不同的容器来处理.nginx处理静态页面效率远高于tomcat,而tomcat擅长动态页面处理,这样一来就能更好的提高并发,处理性能. 所谓负载均衡就是.采用nginx的proxy_pass将location做动静分离后的jsp.do等jsp程序文件分发到后端upstreamd模块中tomcat集群上,re

varnish缓存实现动静分离

 一.简介 Web缓存是指一个Web资源(html,js,css,images...)存在与Web服务器和客户端(浏览器),缓存会根据进来的请求报文做出响应,后缓存一份到本地的缓存中:当下一个请求到来的时候,如果是相同的URL,缓存会根据缓存机制决定是直接使用从缓存中响应访问请求还是向后端服务器再次发送请求,取决于缓存是否过期及其请求的内容是否发生改变.在前面所学的memcached中有过缓存的概念,但此内存缓存存在很大的弊端,被当今互联网企业所淘汰,varnish具有高速缓存的功能,得到了很多

企业实战nginx动静分离安装配置

Nginx Web服务器目前在IT企业中应用最广泛,为什么它会如此让人热爱呢,因为它的高性能.稳定性,而且越来越发展,那Nginx在企业中是如何来应用的呢?Nginx动静分离是如何来配置的呢,今天我们将跟大家一起来构建一个Nginx动静分离的架构. 一.实践环境: 系统版本:CentOS6.0 X86_64 Nginx版本:Nginx-1.2.6 Tomcat版本:Tomcat-6.0.18 二.Nginx安装: 实际环境中安装Nginx,首先需要安装pcre库,然后再安装Nginx: #安装p

Nginx动静分离经典案例配置

随着Nginx高性能Web服务器大量被使用,目前Nginx最新稳定版为1.2.6,张宴兄在实际应用中大量使用Nginx,并分享Nginx高性能Web服务器知识,使得Nginx在国内也是飞速的发展.那今天咱们再来温习一下Nginx 动静分离知识,这里仅供参考. 一.实践环境: 1 2 3 系统版本:CentOS6.0 X86_64 Nginx版本:Nginx-1.2.6 Tomcat版本:Tomcat-6.0.18 二.Nginx安装: 实际环境中安装Nginx,首先需要安装pcre库,然后再安装

Nginx动静分离知识及配置

Nginx动静分离知识及配置,本质上与分离上传下载功能是相同功能,本质就是在文件服务器也是需要部署WEB应用的,只是在进行代理分离的时候分配到对应的文件服务器上去. 随着Nginx高性能Web服务器大量被使用,目前Nginx最新稳定版为1.2.6,张宴兄在实际应用中大量使用Nginx,并分享Nginx高性能Web服务器知识,使得Nginx在国内也是飞速的发展.那今天咱们再来温习一下Nginx 动静分离知识,这里仅供参考. 一.实践环境: 系统版本:CentOS6.0 X86_64 Nginx版本

Ngigx+Tomcat配置动静分离,负载均衡

由于公司使用过Ngnix,对于刚接触Nginx来说,感觉有些好奇,于是研究了下. 本人在windows下使用的版本是nginx-1.8.1: 1. 启动Ngnix 双击nginx-1.8.1文件夹中nginx.exe,当任务管理器中存在两个nginx进程时,则说明启动成功! 2. Ngnix常用命令 nginx -s stop 强制关闭      nginx -s quit 安全关闭      nginx -s reload 改变配置文件的时候,重启nginx工作进程,来时配置文件生效     

基于httpd-2.2和httpd-2.4配置虚拟主机web站点,并提供https服务(一)

使用httpd-2.2和httpd-2.4实现 > 1.建立httpd服务,要求: > 1) 提供两个基于名称的虚拟主机www1, www2:要求每个虚拟主机都有单独的错误日志和访问日志: > 2) 通过www1的/server-status提供状态信息,且仅允许172.16.0.1主机访问: > 3) www2不允许192.168.1.0/24网络中任意主机访问: > 2.为上面的第2)个虚拟主机提供https服务. > 一.使用httpd-2.2实现基于主机名的虚拟

基于httpd-2.2和httpd-2.4配置虚拟主机web站点,并提供https服务(二)

使用httpd-2.2和httpd-2.4实现 > 1.建立httpd服务,要求: > 1) 提供两个基于名称的虚拟主机www1, www2:要求每个虚拟主机都有单独的错误日志和访问日志: > 2) 通过www1的/server-status提供状态信息,且仅允许172.16.0.1主机访问: > 3) www2不允许192.168.1.0/24网络中任意主机访问: > 2.为上面的第2)个虚拟主机提供https服务. > 二.基于httpd-2.4配置虚拟主机web站