概述

Varnish处理HTTP请求的过程大致分为如下几个步骤:
        1> Receive状态:请求处理入口状态,根据VCL规则判断该请求应该Pass或Pipe,还是进入Lookup(本地查询)。
        2> Lookup状态:进入此状态后,会在hash表中查找数据,若找到,则进入Hit状态,否则进入Miss状态。
        3> Fetch状态:在Fetch状态下,对请求进行后端获取,发送请求,获得数据,并进行本地存储。
        4> Deliver状态:将获取到的数据发送给客户端,然后完成本次请求。

Varnish安装完成后,默认的配置文件为/usr/local/varnish/etc/varnish/default.vcl,此文件内容默认全部被注释掉。

VCL

vcl_recv函数

用于接受和处理请求。当请求达到并被成功接收后被调用,通过判断请求的数据来决定如何处理请求。
此函数一般以如下几个关键字结束:

  1. >pass:表示进入pass模式,把请求控制权交给vcl_pass函数。
  2. >pipe:表示进入pipe模式,请把请求控制权交给vcl_pipe函数。
  3. >error code [reason]:表示返回“code”给客户端,并放弃处理该请求。
vcl_pipe函数

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

  1. >pipe:表示进入pipe模式,请把请求控制权交给vcl_pipe函数。
  2. >error code [reason]:表示返回“code”给客户端,并放弃处理该请求。
vcl_pass函数

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

  1. >pass
  2. >error code [reason]:表示返回“code”给客户端,并放弃处理该请求。
lookup

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

vcl_hit函数

在执行lookup指令后,在缓存中找到请求的内容后将自动调用该函数。
此函数一般以如下几个关键字结束:

  1. >pass:表示进入pass模式,把请求控制权交给vcl_pass函数。
  2. >deliver:表示将找到的内容发送给客户端,并把控制权交给vcl_deliver
  3. >error code [reason]:表示返回“code”给客户端,并放弃处理该请求。
vcl_miss函数

在执行lookup指令后,在缓存中没有找到请求的内容时自动调用该方法。此函数可用于判断是否需要从后端服务器获取内容。
此函数一般以如下几个关键字结束:

  1. >pass
  2. >fetch:表示从后端获取请求的内容,并且把控制权交给vcl_fetch
  3. >error code [reason]:表示返回“code”给客户端,并放弃处理该请求。
vcl_fetch函数

在后端主机更新缓存并且获取内容后调用该方法,接着,通过判断获取的内容来决定是将内容放入缓存,还是直接返回给客户端。
此函数一般以如下几个关键字结束:

  1. >pass
  2. >deliver:表示将找到的内容发送给客户端,并把控制权交给vcl_deliver
  3. >error code [reason]:表示返回“code”给客户端,并放弃处理该请求。
vcl_deliver函数

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

  1. >deliver:表示将找到的内容发送给客户端,并把控制权交给vcl_deliver
  2. >error code [reason]:表示返回“code”给客户端,并放弃处理该请求。
vcl_timeout函数

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

  1. >descard:表示从缓存中清楚该内容。
  2. >fetch
vcl_discard函数

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

  1. >descard
  2. >keep:表示将内容继续保留在缓存中。

1.Varnish 安装

  (1) 需要gcc

  (2) 需要pcre ,安装nginx的时候,已经装了

  (3) 需要libedit-dev,安装命令:yum install libedit-dev*

  (4) 去https://www.varnish-cache.org/ 下载,然后进行解压安装,示例如下:
    (1)先解压源码包,然后进入到这个包里面
    (2)安装命令示例如下:
      第一步:因为安装varnish需要pcre,因此先设置一下路径:
        export PKG_CONFIG_PATH=/usr/local/pcre/lib/pkgconfig
      第二步:
        ./configure --prefix=/usr/common/varnish
      第三步:
        配置后就依次 make , make install
      安装过后,如果从外面访问不了,多半是被防火墙挡住了,可以关闭掉防火墙:
        /sbin/service iptables stop

2.运行前的准备

  把配置文件default.vcl上传到 etc/varnish目录里面去

  1. # This is a basic VCL configuration file for varnish. See the vcl(7)
  2. # man page for details on VCL syntax and semantics.
  3. #
  4. # Default backend definition. Set this to point to your content
  5. # server.
  6. #
  7. backend default {
  8. .host = "127.0.0.1";
  9. .port = "8080";
  10. .connect_timeout = 1s;
  11. .first_byte_timeout = 5s;
  12. .between_bytes_timeout = 2s;
  13. }
  14. # ac1 purgeallow {
  15. # "127.0.0.1";
  16. # }
  17. #
  18. # Below is a commented-out copy of the default VCL logic. If you
  19. # redefine any of these subroutines, the built-in logic will be
  20. # appended to your code.
  21. sub vcl_recv {
  22. if(req.request == "PURGE"){
  23. # if(!client.ip ~ purgeallow){
  24. # error 405 "not allowed.";
  25. # }
  26. return(lookup);
  27. }
  28. if(req.request == "GET" && req.url ~ "\.(jpg|png|gif|swf|flv|ico|jpeg)$"){
  29. unset req.http.cookie;
  30. }
  31. if(req.request == "GET" && req.url ~ "(?!)\.jsp($|\?)"){
  32. return(pass);
  33. }
  34. if (req.restarts == 0) {
  35. if (req.http.x-forwarded-for) {
  36. set req.http.X-Forwarded-For =
  37. req.http.X-Forwarded-For + ", " + client.ip;
  38. } else {
  39. set req.http.X-Forwarded-For = client.ip;
  40. }
  41. }
  42. if (req.request != "GET" &&
  43. req.request != "HEAD" &&
  44. req.request != "PUT" &&
  45. req.request != "POST" &&
  46. req.request != "TRACE" &&
  47. req.request != "OPTIONS" &&
  48. req.request != "DELETE") {
  49. /* Non-RFC2616 or CONNECT which is weird. */
  50. return (pipe);
  51. }
  52. if (req.request != "GET" && req.request != "HEAD") {
  53. /* We only deal with GET and HEAD by default */
  54. return (pass);
  55. }
  56. if (req.http.Authorization || req.http.Cookie) {
  57. /* Not cacheable by default */
  58. return (pass);
  59. }
  60. return (lookup);
  61. }
  62.  
  63. sub vcl_pipe {
  64. # # Note that only the first request to the backend will have
  65. # # X-Forwarded-For set. If you use X-Forwarded-For and want to
  66. # # have it set for all requests, make sure to have:
  67. # # set bereq.http.connection = "close";
  68. # # here. It is not set by default as it might break some broken web
  69. # # applications, like IIS with NTLM authentication.
  70. return (pipe);
  71. }
  72. #
  73. sub vcl_pass {
  74. return (pass);
  75. }
  76. #
  77. sub vcl_hash {
  78. hash_data(req.url);
  79. if (req.http.host) {
  80. hash_data(req.http.host);
  81. } else {
  82. hash_data(server.ip);
  83. }
  84. return (hash);
  85. }
  86. #
  87. sub vcl_hit {
  88. return (deliver);
  89. }
  90. #
  91. sub vcl_miss {
  92. return (fetch);
  93. }
  94. #
  95. sub vcl_fetch {
  96. if (beresp.ttl <= 0s ||
  97. beresp.http.Set-Cookie ||
  98. beresp.http.Vary == "*") {
  99. # /*
  100. # * Mark as "Hit-For-Pass" for the next 2 minutes
  101. # */
  102. set beresp.ttl = 120 s;
  103. return (hit_for_pass);
  104. }
  105. return (deliver);
  106. }
  107. #
  108. sub vcl_deliver {
  109. return (deliver);
  110. }
  111. #
  112. # sub vcl_error {
  113. # set obj.http.Content-Type = "text/html; charset=utf-8";
  114. # set obj.http.Retry-After = "5";
  115. # synthetic {"
  116. # <?xml version="1.0" encoding="utf-8"?>
  117. # <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
  118. # "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
  119. # <html>
  120. # <head>
  121. # <title>"} + obj.status + " " + obj.response + {"</title>
  122. # </head>
  123. # <body>
  124. # <h1>Error "} + obj.status + " " + obj.response + {"</h1>
  125. # <p>"} + obj.response + {"</p>
  126. # <h3>Guru Meditation:</h3>
  127. # <p>XID: "} + req.xid + {"</p>
  128. # <hr>
  129. # <p>Varnish cache server</p>
  130. # </body>
  131. # </html>
  132. # "};
  133. # return (deliver);
  134. # }
  135. #
  136. sub vcl_init {
  137. return (ok);
  138. }
  139. #
  140. sub vcl_fini {
  141. return (ok);
  142. }

  

3.运行的基本命令示例

  进入/usr/common/varnish/sbin,运行下面的命令

  ./varnishd -f /usr/common/varnish/etc/varnish/default.vcl -s malloc,32M -T
  127.0.0.1:2000 -a 0.0.0.0:1111
  其中:1:-f 指定要运行的配置文件
     2: -s malloc,32M :–s 选项用来确定varnish使用的存储类型和存储容量,这里使用
     的是malloc类型(malloc是一个C函数,用于分配内存空间)
     3:-T 127.0.0.1:2000 : 指定varnish的管理ip和端口
     4: -a 0.0.0.0:1111 :指定varnish对外提供web服务的ip和端口
  接下来就可以测试一下了:
  http://192.168.0.106:1111/arch1/goods/toList ,这是访问varnish的
  http://192.168.0.106:8080/arch1/goods/toList ,这是直接访问Tomcat的

备注:192.168.0.106是我的虚拟机地址,

防火墙关闭:

  1. service iptables stop
  2. service ip6tables stop
  3. chkconfig iptables off
  4. chkconfig ip6tables off

4.关闭varnish

  到valish/sbin的路径下,运行 pkill varnishd

7.Varnish的更多相关文章

  1. 利用varnish做Discuz论坛的缓存服务器

    实验背景:公司有一台BBS服务器,用的是LNMP的架构搭建的.正好手头有一台空闲的虚拟机,于是想着给BBS前端加一台缓存服务器.于是选定了varnish,搜了很多教程,跌跌撞撞的完成了配置.这其中很多 ...

  2. varnish 隐藏版本号

    varnish 隐藏方法: 修改default.vcl配置文件. 找到或添加 vcl_deliver 子程序,代码如下: 1 2 3 4 5 sub vcl_deliver {        unse ...

  3. [转]在windows环境中使用varnish

    varnish 的windows 版本下载地址: http://sourceforge.net/projects/cygvarnish/files/windows-zip-bundle/ 启动:var ...

  4. Varnish常用相关命令工具

    varnishd启动./varnishd  -f /usr/local/varnish-3.0.2/etc/varnish/default.vcl -s malloc,1G -T 127.0.0.1: ...

  5. Varnish介绍

    “Varnish是一款高性能的开源HTTP加速器,挪威最大的在线报纸 Verdens Gang (http://www.vg.no) 使用3台Varnish代替了原来的12台squid,性能居然比以前 ...

  6. varnish 内置函数详细说明

    Subroutine列表 •vcl_recv 在请求开始时候被调用,在请求已经被接收到并且解析后调用.目的就是决定是否处理这个请求,怎么处理,使用哪个后端.vcl_recv以return结束,参数可以 ...

  7. varnish 4.0.3 域名访问的小问题

    1,若端口不是80 端口则匹配的时候必须加端口 if (req.http.host ~ "(?i)^var.test.aa:6081$") {set req.http.host = ...

  8. Varnish简介

    Varnish介绍: Varnish是一个反向HTTP代理,有时也被称为HTTP的加速器或网络加速器:它存在于真实服务器的前面(可能有多级代理),将来自于客户端的请求中的部分内容存储在自身的内存中,以 ...

  9. 学习varnish随笔

    Varnish是一款高性能.开源的反向代理服务器和缓存服务器.Varnish使用内存缓存文件来减少响应时间和网络带宽消耗.这个项目是由挪威的一家报纸Verdens Gang的网络分支起始的,其架构设计 ...

  10. varnish

    html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,bi ...

随机推荐

  1. 原生java与js结合

    链接:https://www.jb51.cc/html5/15606.html

  2. spring与jdbc,mybatis的结合

    关键点在于把DataSource(数据源)配置到spring容器中,通过数据源获取数据库连接对象 数据库连接池(pool):管理数据库连接对象 四种数据源: 1)<!-- 基于jdk的规范数据源 ...

  3. java ArrayList添加元素全部一样

    #开始 今天遇到了一个很神奇的事情 也即是我在用ArrayList的add方法循环加入对象的时候 发现添加的元素全部都是一样的 定位错误定位了一个下午.... 错误位置就是哪一个位置 但是就是不知道为 ...

  4. HDU 1069 Monkey and Banana(线性DP)

    Description   A group of researchers are designing an experiment to test the IQ of a monkey. They wi ...

  5. Android学习03

    ToggleButton和Switch 状态开关ToggleButton与开关switch也是由button按钮派生出来的,因此他们的本质也是按钮,button支持的各种属性,方法toggleButt ...

  6. 【原】django实现列表分页功能

    在view.py里添加分页查询方法: from django.http import JsonResponse from django.views.decorators.http import req ...

  7. 使用 yum 安装 MariaDB 与 MariaDB 的简单配置

    1.安装MariaDB 安装命令 yum -y install mariadb mariadb-server 安装完成MariaDB,首先启动MariaDB,两条命令都可以 systemctl sta ...

  8. MySQL忘记密码(终极解决方法,亲测有效,windows版本)

    1.进入mysql的bin目录 2.net stop mysql 3.mysqld --skip-grant-tables 输入 mysqld --skip-grant-tables 回车. (--s ...

  9. coturn服务器配置中英对比

    coturn服务器配置中英对比 默认配置位置 /etc/turnserver.conf # RFC5766-TURN-SERVER configuration file # RFC5766-TURN- ...

  10. Vue-footer始终置底

    需求:当页面高度不足一屏时需要footer固定显示在页面底部,而页面内容超过一屏时需要footer紧跟在页面内容的最后. 思路:通过获取 网页可见区域高度:document.body.clientHe ...