转自:http://ixdba.blog.51cto.com/2895551/682555
 

一、安装Varnish

Varnish的安装非常简单,下面逐步介绍:

1、安装前的准备

 Varnish安装环境如下表1所示:

表1

主机名              操作系统                    IP地址

Varnish-server CentOS release 5.4    192.168.12.246

Web-server     CentOS release 5.4    192.168.12.26

接着,建立varnish用户以及用户组,并且创建Varnish缓存目录和日志目录:

[root@varnish-server ~]#useradd  -s /sbin/nologin varnish

[root@varnish-server ~]#mkdir /data/varnish/cache

[root@varnish-server ~]#mkdir /data/varnish/log

[root@varnish-server ~]#chown -R varnish:varnish  /data/varnish/cache

[root@varnish-server ~]#chown -R varnish:varnish  /data/varnish/log

2、获取varnish软件

 Varnish的官方站点为http://varnish-cache.org
这里面有varnish的最新说明文档,以及版本升级记录,从此站点可以找到varnish在SourceForge的下载链接,目前,varnish的
最新版本是Varnish 2.1.2,下载完成后的包名为varnish-2.1.2.tar.gz,此处我们就以此版本为例,进行安装配置。

3、安装pcre

如果没有安装Pcre,在编译varnish2.0以上版本时,会提示找不到pcre库,而pcre库是为了兼容正则表达式,所以必须先安装pcre库。

[root@varnish-server ~]#tar zxvf pcre-7.9.tar.gz

[root@varnish-server ~]#cd pcre-7.9/

[root@varnish-server ~]#./configure --prefix=/usr/local/pcre/

[root@varnish-server ~]#make && make install

4、安装varnish

这里我们将varnish安装到/usr/local/目录下,操作如下:

[root@varnish-server ~]#tar -zxvf varnish-2.1.2.tar.gz

[root@varnish-server ~]#cd varnish-2.1.2

[root@varnish-server ~]#export PKG_CONFIG_PATH=/usr/local/pcre/lib/pkgconfig

[root@varnish-server ~]#./configure --prefix=/usr/local/varnish \

 >--enable-dependency-trackin

>--enable-debugging-symbols

>--enable-developer-warnings

[root@varnish-server ~]#make

[root@varnish-server ~]#make install

[root@varnish-server ~]#cp redhat/varnish.initrc  /etc/init.d/varnish

[root@varnish-server ~]#cp redhat/varnish.sysconfig  /etc/sysconfig/varnish

 其中,“PKG_CONFIG_PATH”是指定varnish查找pcre库的路径,如果pcre安装在了其它路径下,在这里指定相应的路径即
可,Varnish默认查找的pcre库路径为/usr/local/lib/
pkgconfig。最后两步操作是拷贝一些varnish守护进程的初始化脚本文件,这些脚本用于varnish的启动、关闭管理等方面,在下面章节中
会进行详细讲解。

 至此,varnish安装完毕。

二、配置Varnish



1、VCL使用说明

VCL,即为Varnish Configuation
Language,用来定义varnish的存取策略,VCL语法比较简单,跟C和perl比较相似,可以使用指定运算符“=”,比较运算符“==”,逻
辑运算符“!,&&,!!”等形式。还支持正则表达样和用“~”进行ACL匹配运算,同时还可以使用“set”这样的关键字来指定变量。

需要注意的是,“\”字符在VCL里没有特别的含义,这点与其它语言略有不同,另外,VCL只是配置,并不是真正的编程语言,没有循环,也没有自定义变量。 

在讲述Varnish配置之前,首先需要了解下varnish的配置语法,即VCL,下面对VCL常用的一些内置函数和公用变量进行详细介绍。

VCL内置函数

(1)vcl_recv函数

用于接收和处理请求,当请求到达并成功接收后被调用,通过判断请求的数据来决定如何处理请求。

此函数一般以如下几个关键字结束:

 pass:表示进入pass模式,把请求控制权交给vcl_pass函数。

 pipe:表示进入pipe模式,把请求控制权交给vcl_pipe函数。

 error code [reason]:表示返回“code”给客户端,并放弃处理该请求,“code”是错误标识,例如200、405等,“reason”是错误提示信息。

(2)vcl_pipe函数

此函数在进入pipe模式时被调用,用于将请求直接传递至后端主机,在请求和返回的内容没有改变的情况下,将不变的内容返回给客户端,直到这个链接关闭。

此函数一般以如下几个关键字结束:

 error code [reason]

 pipe

(3)vcl_pass函数

此函数在进入pass模式时被调用,用于将请求直接传递至后端主机,后端主机应答数据后送给客户端,但不进行任何缓存,在当前连接下每次都返回最新的内容。

此函数一般以如下几个关键字结束:

 error code [reason]

 pass

(4)lookup

表示在缓存里查找被请求的对象,并且根据查找的结果把控制权交给函数vcl_hit或者函数vcl_miss。

(5)vcl_hit函数

在执行lookup指令后,如果在缓存中找到请求的内容,将自动调用该函数。

此函数一般以如下几个关键字结束:

 deliver:表示将找到的内容发送给客户端,并把控制权交给函数vcl_deliver。

 error code [reason]

 pass

(6)vcl_miss函数

在执行lookup指令后,如果没有在缓存中找到请求的内容时自动调用该方法,此函数可以用于判断是否需要从后端服务器取内容。

此函数一般以如下几个关键字结束:

 fetch:表示从后端获取请求的内容,并把控制权交给vcl_fetch函数。

 error code [reason]

 pass

(7)vcl_fetch函数

在从后端主机更新缓存并且获取内容后调用该方法,接着,通过判断获取的内容来决定是否将内容放入缓存,还是直接返回给客户端。

此函数一般以如下几个关键字结束:

 error code [reason]

 pass

 deliver

(8)vcl_deliver函数

在缓存中找到请求的内容后,发送给客户端前调用此方法。此函数一般以如下几个关键字结束:

 error code [reason]

 deliver

(9)vcl_timeout 函数

此函数在缓存内容到期前调用。一般以如下几个关键字结束:

 discard:表示从缓存中清除该内容。

 fetch

(10)vcl_discard函数

在缓存内容到期后或缓存空间不够时,自动调用该方法,一般以如下几个关键字结束:

 keep:表示将内容继续保留在缓存中。

 discard

2、VCL处理流程图

 通过上面对VCL函数的介绍,读者对各个函数实现的功能已经有了一个了解,其实每个函数之间都是相互关联的,下图列出了varnish处理HTTP请求的一个运行流程图。

处理过程大致分为如下几个步骤:

(1) Receive状态,也就是请求处理的入口状态,根据VCL规则判断该请求应该是Pass或Pipe,或者进入Lookup(本地查询)。

(2) Lookup状态,进入此状态后,会在hash表中查找数据,若找到,则进入Hit状态,否则进入miss状态。

(3) Pass状态,在此状态下,会进入后端请求,即进入fetch状态。

(4) Fetch状态,在Fetch状态下,对请求进行后端的获取,发送请求,获得数据,并进行本地的存储。

(5) Deliver状态, 将获取到的数据发送给客户端,然后完成本次请求。

3、内置公用变量

 VCL内置的公用变量可以用在不同的VCL函数中,根据这些公用变量使用的不同阶段,下面依次介绍。

当请求到达后,可以使用的公用变量如表2所示:

表2

公用变量名称    含义

req.backend        指定对应的后端主机

server.ip              表示服务器端IP

client.ip               表示客户端IP

req.request          指定请求的类型,例如GET、HEAD、POST等

req.url                 指定请求的地址

req.proto            表示客户端发起请求的HTTP协议版本

req.http.header   表示对应请求中的http头部信息

req. restarts         表示请求重启的次数,默认最大值为4

Varnish               在向后端主机请求时,可以使用的公用变量如表3所示:

表3

公用变量名称 含义

beresp.request 指定请求的类型,例如GET、HEAD等

beresp.url 指定请求的地址

beresp .proto 表示客户端发起请求的HTTP协议版本

beresp .http.header 表示对应请求中的http头部信息

beresp .ttl 表示缓存的生存周期,也就是cache保留多长时间,单位是秒

从cache或者后端主机获取内容后,可以使用的公用变量如表4所示:

表4

公用变量名称 含义

obj.status 表示返回内容的请求状态代码,例如200、302、504等

obj.cacheable 表示返回的内容是否可以缓存,也就是说,如果HTTP返回是200、203、300、301、302、404、410等,并且有非0的生存期,则可以缓存

obj.valid 表示是否是有效的HTTP应答

obj.response 表示返回内容的请求状态信息

obj.proto 表示返回内容的HTTP协议版本

obj.ttl 表示返回内容的生存周期,也就是缓存时间,单位是秒

obj.lastuse 表示返回上一次请求到现在的间隔时间,单位是秒

对客户端应答时,可以使用的公用变量如表5所示:

表5

公用变量名称 含义

resp.status 表示返回给客户端的HTTP状态代码

resp.proto 表示返回给客户端的HTTP协议版本

resp.http.header 表示返回给客户端的HTTP头部信息

resp.response 表示返回给客户端的HTTP状态信息

在上面的讲述中,我们只是介绍了常用的VCL内置公用变量,如果需要了解和使用更多的公用变量信息,请登录varnish官方网站查阅。

三 、配置一个简单的Varnish实例

 由于版本的不同,Varnish配置文件的写法也存在一定差异,varnish2.x版本和1.x版本之间不但配置文件写法不同,而且新的版本功能也增
加很多,并且去除了很多应用BUG,这里讲述的版本是varnish2.1.2,配置文件写法也以varnish2.x版本为基准。

Varnish安装完成后,默认的配置文件为/usr/local/varnish/etc/varnish/default.vcl,此文件内容默认全
部被注释掉了,这里,我们以这个文件为模板,创建一个新的文件vcl.conf,并且放到/usr/local/varnish/etc目录下,配置完成
的vcl.conf文件如下:

#通过backend定义了一个名称为webserver的后端主机,“.host”指定后端主机的IP地址或者域名,“.port”指定后端主机的服务端口。其中,“192.168.12.26”就是后端的一个web服务器。

backend webserver {

     .host = "192.168.12.26";

     .port = "80";

 }

#调用vcl_recv开始。

sub vcl_recv {

        if (req.http.x-forwarded-for) {

                set req.http.X-Forwarded-For =

                    req.http.X-Forwarded-For ", " client.ip;

        } else {

                set req.http.X-Forwarded-For = client.ip;

        }

#如果请求的类型不是GET、HEAD、PUT、POST、TRACE、OPTIONS、DELETE时,进入pipe模式。注意这里是“&&”的关系。

        if (req.request != "GET" &&

           req.request != "HEAD" &&

           req.request != "PUT" &&

           req.request != "POST" &&

           req.request != "TRACE" &&

           req.request != "OPTIONS" &&

           req.request != "DELETE") {

           return (pipe);

        }

#如果请求的类型不是GET与HEAD,则进入pass模式。

   if (req.request != "GET" && req.request != "HEAD") {

           return (pass);

        }

#对ixdba.net或者ixdba.cn两个域名进行缓存加速,这是个泛域名的概念,也就是所有以ixdba.net或者ixdba.cn结尾的域名都进行缓存。

        if (req.http.host ~ "^(.*).ixdba.net" || req.http.host ~ "^(.*).ixdba.cn") {

           set req.backend = webserver;

        }

#对以.jsp和.do结尾以及带有?的URL时,直接从后端服务器读取内容。

        if (req.url ~ "\.(jsp|do)($|\?)") {

           return (pass);

        } else {

        return (lookup);

        }

}

 

sub vcl_pipe {

    return (pipe);

}

 

sub vcl_pass {

    return (pass);

}

 

sub vcl_hash {

    set req.hash += req.url;

    if (req.http.host) {

        set req.hash += req.http.host;

    } else {

        set req.hash += server.ip;

    }

    return (hash);

}

 

sub vcl_hit {

    if (!obj.cacheable) {

        return (pass);

    }

    return (deliver);

}

 

sub vcl_miss {

    return (fetch);

}

 

sub vcl_fetch {

     if (!beresp.cacheable) {

         return (pass);

     }

     if (beresp.http.Set-Cookie) {

         return (pass);

     }

#当url中包含servlet时,不进行缓存。

    if (req.url ~ "^/servlet/") {

        return (pass);

    }

#当url中包含services时,不进行缓存。

    if (req.url ~ "^/services/") {

        return (pass);

    }

#对于请求类型是GET,并且请求的URL中包含upload,那么就进行缓存,缓存的时间是300秒,即5分钟。

    if (req.request == "GET" && req.url ~ "^/upload(.*)$") {

       set beresp.ttl = 300s;

    }

#对于请求类型是GET,并且请求的URL以png、xsl、xml、gif、css、js等结尾时,则进行缓存,缓存时间为600秒。

    if (req.request == "GET" && req.url ~
"\.(png|xsl|xml|pdf|ppt|doc|docx|chm|rar|zip|bmp|jpeg|swf|ico|mp3|mp4|rmvb|ogg|mov|avi|wmv|swf|txt|png|gif|jpg|css|js|html|htm)$")
{

       set beresp.ttl = 600s;

    }

    return (deliver);

}

  #下面是添加一个Header标识,以判断缓存是否命中。

sub vcl_deliver {

    if (obj.hits > 0) {

       set resp.http.X-Cache = "HIT from www.ixdba.net";

    } else {

      set resp.http.X-Cache = "MISS from www.ixdba.net";

    }

    return (deliver);

}

 
安装过程中会遇到的坑 :
 
yum -y install automake autoconf libtool ncurses-devel libxslt groff pcre-devel pkgconfig
yum install libedit-devel
yum install pcre-deve -y

安装Varnish 及遇到的坑的更多相关文章

  1. 在WIN SERVER 2016上安装DOCKER(带过坑)

    目录 1    概要    1 1.1    主要优势    1 2    在Windows Server上部署Docker    2 概要 博客使用Word发博,发布后,排版会出现很多问题,敬请谅解 ...

  2. Ubuntu 16.04 安装Mysql 5.7 踩坑小记

    title:Ubuntu 16.04 安装Mysql 5.7 踩坑小记 date: 2018.02.03 安装mysql sudo apt-get install mysql-server mysql ...

  3. Cloudera Manager 安装集群遇到的坑

    Cloudera Manager 安装集群遇到的坑 多次安装集群,但每次都不能顺利,都会遇到很多很多的坑,今天就过去踩过的坑简单的总结一下,希望已经踩了的和正在踩的童鞋能够借鉴一下,希望对你们能有所帮 ...

  4. cnetos6.5安装Varnish

    安装依赖包: tar -zxvf docutils-0.13.1.tar.gz python setup.py install unzip pcre2-10.23.zip ./configure -- ...

  5. superset的安装(win10)踩踩坑!AWSL

    基本安装参考https://www.jianshu.com/p/8b27ff71429f 按此方案装的时候会遇到各种flask版本不兼容的问题,所以 第一步:装好anaconda 第二部:保证好高于V ...

  6. 分享一下我在mysql5.6+mysql8数据库安装过程中的一些坑!

    Mysql5.6安装 下载好安装包后,在bin目录下用cmd打开,输入mysqld install [服务名]新建个服务 在windows+r输入services.msc即可查看服务 怎样使用mysq ...

  7. 那些最全面的Windows10安装pytorch踩过的坑以及如何应用

    那些最全面的Windows10安装pytorch踩过的坑以及如何应用 一.pytorch简介 2017年1月,由Facebook人工智能研究院(FAIR)基于Torch推出了PyTorch.它是一个基 ...

  8. Nebula 2.5.0安装过程及遇到的坑

    2021年8月23日,Nebula 发布了最新版本:2.5.0,正好赶上新环境部署,记录一下安装过程及遇到的坑: 一.准备工作 以下安装使用nebula用户,搭建集群模式,一共三台机器:192.168 ...

  9. [异常解决] ubuntu上安装JLink驱动遇到的坑及给后来者的建议

    一.前言 最近将整个电脑格式化,改成了linux操作系统 希望这样能让自己在一个新的世界探索技术.提升自己吧- win上的工具用多了,就不想变化了- 继上一篇<ubuntu上安装虚拟机遇到的问题 ...

随机推荐

  1. css中cursor(光标类型)

    值 描述 url 需使用的自定义光标的 URL. 注释:请在此列表的末端始终定义一种普通的光标,以防没有由 URL 定义的可用光标. default 默认光标(通常是一个箭头) auto 默认.浏览器 ...

  2. nginx 安装配置及使用 启动权限拒绝问题

    安装 yum install -y nginx 查看安装的路径 whereis nginx 可能会有所不同 需要根据自己的查看 执行目录:/usr/sbin/nginx 模块所在目录:/usr/lib ...

  3. minio文件上传与下载

    目录 一.minio简介 二.minio安装 一.java中使用 一.minio简介 MinIO 是在 GNU Affero 通用公共许可证 v3.0 下发布的高性能对象存储. 它是与 Amazon ...

  4. Flutter 让你的Dialog脱胎换骨吧!(Attach,Dialog,Loading,Toast)

    前言 Q:你一生中闻过最臭的东西,是什么? A:我那早已腐烂的梦. 兄弟萌!!!我又来了! 这次,我能自信的对大家说:我终于给大家带了一个,能真正帮助大家解决诸多坑比场景的pub包! 将之前的flut ...

  5. 初识python: 自定义函数

    什么是函数? 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段.函数能提高应用的模块性,和代码的重复利用率. 函数的定义方法: def test(x): '函数定义方法' x+=1 r ...

  6. MySQL删除数据库或表(DROP DATABASE/table语句)

    DROP DATABASE [ IF EXISTS ] <数据库名> DROP table[ IF EXISTS ] <数据库表名> 语法说明如下: <数据库名>: ...

  7. [解决] No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android

    前端时间项目组让我改一个比较老的项目,说是用Android Studio2.3版本可以直接运行,于是我下载了一个2.3.2的,结果出现了一堆问题,总结下: 首先导入项目后build完直接报出:No t ...

  8. Solon 开发,八、注入依赖与初始化

    Solon 开发 一.注入或手动获取配置 二.注入或手动获取Bean 三.构建一个Bean的三种方式 四.Bean 扫描的三种方式 五.切面与环绕拦截 六.提取Bean的函数进行定制开发 七.自定义注 ...

  9. 《剑指offer》面试题39. 数组中出现次数超过一半的数字

    问题描述 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字. 你可以假设数组是非空的,并且给定的数组总是存在多数元素. 示例 1: 输入: [1, 2, 3, 2, 2, 2, 5, 4, ...

  10. 【Android】安卓开发中的布局与事件

    [Android]安卓开发中的布局与事件 1.Android Studio下载配置 非常简单的百度然后点击下载安装就好了.注意的是,本来我是打算使用评价还不错的Genymotion这个软件来充当虚拟机 ...