`

Varnish配置

 
阅读更多
# This is a basic VCL configuration file for varnish.  See the vcl(7)
# man page for details on VCL syntax and semantics.
# 
# Default backend definition.  Set this to point to your content
# server.
 
backend tgweb {
     .host = "192.168.45.45";
     .port = "7574";
     .connect_timeout = 20s;
     .first_byte_timeout = 20s;
     .between_bytes_timeout = 20s;
 }

#允许刷新缓存的规则
#acl purgeAllow {
#     #只能本机进行刷新
#     "localhost";
#}
 
# Below is a commented-out copy of the default VCL logic.  If you
# redefine any of these subroutines, the built-in logic will be
# appended to your code.

sub vcl_recv {
	#判断请求主机,跳转到相应后端服务器
    if(req.http.host ~ "^(.*)(tg.stockjyb.com:7575)")
	{
		set req.backend=tgweb;
	}else{
		error 408 "Hostname not found"; 
	}
    
    #grace缓存过期仍存放
    # 若backend是健康的,则仅grace 5s,如果backend不健康,则grace 1m。
    # 这里,5s的目的是为了提高高并发时的吞吐率;
    # 1m的目的是,backend挂了之后,还能继续服务一段时间,期望backend挂的不要太久。。。
    if (req.backend.healthy) {
        set req.grace = 5s;
    } else {
        set req.grace = 1m;
    }

	#刷新缓存的处理
    #if (req.request == "PURGE"){
    #    if(!client.ip ~ purgeAllow) {
    #            error 405 "Not allowed.";
    #    }
    #    #转到hit或者miss处理
    #    return (lookup);
    #}

	#移除一些特定格式的cookie
    if (req.url ~ "^(.*)\.(jpg|png|gif|jpeg|flv|bmp|gz|tgz|bz2|tbz|js|css|html|htm)($|\?)" ) {
         #移除cookie,以便能缓存到varnish
         unset req.http.cookie;
    }

   #Accept-Encoding 是浏览器发给服务器,声明浏览器支持的编码类型的
   #修正客户端的Accept-Encoding头信息
   #防止个别浏览器发送类似 deflate, gzip
 	if (req.http.Accept-Encoding) {
	    if (req.url ~ "^(.*)\.(jpg|png|gif|jpeg|flv|bmp|gz|tgz|bz2|tbz)($|\?)" ) {
		    remove req.http.Accept-Encoding;
  	    }else if (req.http.Accept-Encoding ~ "gzip"){
            set req.http.Accept-Encoding = "gzip";
  	    } else if (req.http.Accept-Encoding ~ "deflate"){
            set req.http.Accept-Encoding = "deflate";
  	    } else if (req.http.Accept-Encoding ~ "sdch"){
            #chrome新增加的压缩
            set req.http.Accept-Encoding = "sdch";
  	    }else {
            remove req.http.Accept-Encoding;
        }
 	}
      
    #首次访问增加X-Forwarded-For头信息,方便后端程序获取客户端ip
    if (req.restarts == 0) {
		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;
		}
    }

   #if (req.request != "GET" &&
   #    req.request != "HEAD" &&
   #    req.request != "PUT" &&
   #    req.request != "POST" &&
   #    req.request != "TRACE" &&
   #    req.request != "OPTIONS" &&
   #    req.request != "DELETE") {
   #    /* Non-RFC2616 or CONNECT which is weird. */
   #    return (pipe);
   #}
     if (req.request != "GET" && req.request != "HEAD") {
         /* We only deal with GET and HEAD by default */
         return (pass);
     }
     if (req.http.Authorization) {
         /* Not cacheable by default */
         return (pass);
     }
     #js,css文件都有Cookie,不能每次都去后台服务器去取
     #if (req.http.Cookie) {
     #    /* Not cacheable by default */
     #    return (pass);
     #}
	
     #如果请求的是动态页面直接转发到后端服务器
     if (req.url ~ "^(.*)\.(aspx|asmx|ashx)($|.*)") {
          return (pass);
     }
     return (lookup);
 }
 
 sub vcl_pipe {
     # Note that only the first request to the backend will have
     # X-Forwarded-For set.  If you use X-Forwarded-For and want to
     # have it set for all requests, make sure to have:
     # set bereq.http.connection = "close";
     # here.  It is not set by default as it might break some broken web
     # applications, like IIS with NTLM authentication.
     return (pipe);
 }
 
#放过,让其直接去后台服务器请求数据
 sub vcl_pass {
     return (pass);
 }
 
 sub vcl_hash {
     hash_data(req.url);
     if (req.http.host) {
         hash_data(req.http.host);
     } else {
         hash_data(server.ip);
     }
     #支持压缩的要增加,防止发送给不支持压缩的浏览器压缩的内容
     if(req.http.Accept-Encoding){
          hash_data(req.http.Accept-Encoding);
     }
     return (hash);
 }
 
#缓存服务器lookup查找命中:hit
 sub vcl_hit {
     #刷新缓存的请求操作,设置TTL为0,返回处理结果代码
     #if (req.request == "PURGE") {
     #     set obj.ttl = 0s;
     #     error 200 "Purged.";
     # }

     //#缓存服务器命中后(查找到了)
     return (deliver);
 }
 
#缓存服务器lookup查找没有命中:miss
 sub vcl_miss {
    #刷新缓存的请求操作,
    #if (req.request == "PURGE") {
    #    error 404 "Not in cache.";
    #}

    //#缓存服务器没有命中(去后台服务器取)
     return (fetch);
 }
 
#从后台服务器取回数据后,视情况是否进行缓存
 sub vcl_fetch {

    #如果请求的是动态页面直接发转发
    #动态请求回来的,一定要放在前面处理
    if (req.url ~ "^(.*)\.(aspx|asmx|ashx)($|.*)") {
        set beresp.http.Cache-Control="no-cache, no-store";
        unset beresp.http.Expires;
        return (deliver);
    }

    # 仅当该请求可以缓存时,才设置beresp.grace,若该请求不能被缓存,则不设置beresp.grace
    if (beresp.ttl > 0s) {
        set beresp.grace = 1m;
    }  

     if (beresp.ttl <= 0s ||
         beresp.http.Set-Cookie ||
         beresp.http.Vary == "*") {
     		/*
     		 * Mark as "Hit-For-Pass" for the next 2 minutes
     		 */
     		set beresp.ttl = 120 s;
     		#下次请求时不进行lookup,直接pass
     		return (hit_for_pass);
     }

    #设置从后台服务器获得的特定格式文件的缓存TTL
    if (req.url ~ "^(.*)\.(pdf|xls|ppt|doc|docx|xlsx|pptx|chm|rar|zip)($|\?)")     
    {
		#移除服务器发送的cookie 
		unset beresp.http.Set-Cookie;
		#加上缓存时间
        set beresp.ttl = 30d;
	    return (deliver);
    }else if(req.url ~ "^(.*)\.(bmp|jpeg|jpg|png|gif|svg|png|ico|txt|css|js|html|htm)($|\?)"){
		#移除服务器发送的cookie 
		unset beresp.http.Set-Cookie;
		#加上缓存时间
        set beresp.ttl = 15d;
	    return (deliver);
	}else if(req.url ~ "^(.*)\.(mp3|wma|mp4|rmvb|ogg|mov|avi|wmv|mpeg|mpg|dat|3pg|swf|flv|asf)($|\?)"){
		#移除服务器发送的cookie 
		unset beresp.http.Set-Cookie;
		#加上缓存时间
        set beresp.ttl = 30d;
	    return (deliver);
	}

	#从后台服务器返回的response信息中,没有缓存的,不缓存
	if (beresp.http.Pragma ~"no-cache" || beresp.http.Cache-Control ~"no-cache" || beresp.http.Cache-Control ~"private") {
            return (deliver);
   	}
    return (deliver);
 }
 
#缓存服务器发送到客户端前调用
 sub vcl_deliver {
    #下面是添加一个Header标识,以判断缓存是否命中。
    if (obj.hits > 0) {
        set resp.http.X-Cache = "HIT from TG.varnish-cache.jjcj.com";
	   #set resp.http.X-Varnish = "HIT from TG.varnish-cache.jjcj.com";
    } else {
        set resp.http.X-Cache = "MISS from TG.varnish-cache.jjcj.com";
	   #set resp.http.X-Varnish = "MISS from TG.varnish-cache.jjcj.com";
    }
    #去掉不是必须的header
    unset resp.http.Vary;
    unset resp.http.X-Powered-By;
    unset resp.http.X-AspNet-Version;
    return (deliver);
 }
 
 sub vcl_error {
     set obj.http.Content-Type = "text/html; charset=utf-8";
     set obj.http.Retry-After = "5";
     synthetic {"
 <?xml version="1.0" encoding="utf-8"?>
 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
 <html>
   <head>
     <title>"} + obj.status + " " + obj.response + {"</title>
   </head>
   <body>
     <h1>Error "} + obj.status + " " + obj.response + {"</h1>
     <p>"} + obj.response + {"</p>
     <h3>Guru Meditation:</h3>
     <p>XID: "} + req.xid + {"</p>
     <hr>
     <p>Varnish cache server</p>
   </body>
 </html>
 "};
     return (deliver);
 }
 
 sub vcl_init {
 	return (ok);
 }
 
 sub vcl_fini {
 	return (ok);
 }
分享到:
评论

相关推荐

    linux-varnish配置

    Linux环境下的Varnish配置涉及到安装、配置文件的修改、启动和管理、监控以及性能优化等多个环节。理解并掌握Varnish的基本工作原理和VCL语言,是有效利用Varnish提高Web性能的关键。通过不断的实践和调整,Varnish...

    Varnish配置教程和学习资料合集

    教程名称: Varnish配置教程和学习资料合集【】HTTP加速器varnish安装部署【】varnish cache 配置使用ChinaUnix【】varnish 原理【】Varnish-vcl的配置【】varnish配置实例 资源太大,传百度网盘了,链接在附件中,...

    Varnish配置笔记记录.docx

    以下是对Varnish配置过程的详细说明: 首先,为了准备安装Varnish,你需要确保系统中安装了必要的依赖库。在描述中,可以看到需要执行的yum命令,包括automake、autoconf、libtool、ncurses-devel、libxslt、groff...

    nginx和php和varnish配置

    nginx和php和varnish配置

    Varnish安装配置

    Varnish是一款高性能的开源HTTP加速器,挪威最大的在线报纸 Verdens Gang 使用3台Varnish代替了原来的12台Squid,性能比以前更好。 本文档详细讲解了varnish的安装配置过程以及配置文件详解

    prerender-varnish:prerender-varnish是Varnish配置,用于使用prerender.io从Javascript pagesapps提供预渲染HTML

    要使用prerender-varnish,请在您的Varnish配置目录(通常是/etc/varnish )中将prerender.vcl和prerender_backend.vcl符号链接起来,并将它们添加到您的主要Varnish配置文件中: include " prerender.vcl " ; 更新...

    Varnish配置文件详解(架构师之路)

    既然Varnish需要在多台服务器上缓存数据,...该块配置用于定义一台Varnish默认访问的后端服务器,当Varnish需要从后端服务器获取数据时,就会访问自己的80端口。 当然Varnish也可以定义多台后端服务器实现负载均衡的目

    Varnish3.0.5的安装配置.txt

    - `-f`指定VCL(Varnish配置语言)文件的位置。 - `-smalloc,1G`设置缓存的大小为1GB。 - `-T 0.0.0.0:2000`开启管理控制台监听在所有IP地址的2000端口上。 - `-a 0.0.0.0:8000`指定Varnish监听所有IP地址上的...

    高命中率的varnish缓存配置分享

    首先,我们来看一下基础的Varnish配置。在示例中,定义了一个名为`slogra`的后端服务器,其IP地址为`172.0.0.1`,监听80端口。设置连接超时时间为20秒,第一字节和字节间超时时间同样为20秒。这样的配置确保了...

    varnish安装配置[参照].pdf

    在实际部署中,Varnish配置文件会根据业务需求进行调整,例如根据URL、User-Agent、Cookie等进行更复杂的缓存策略设定。此外,Varnish还提供了丰富的管理工具,如varnishadm、varnishlog等,方便监控和调试缓存服务...

    Varnish权威指南(中文)

    2. 定制化:Varnish配置语言VCL(Varnish Configuration Language)允许用户自定义缓存策略,根据需求调整缓存规则。 3. 动态内容缓存:Varnish支持ESI(Edge Side Includes),可以在缓存页面中嵌入动态内容。 4. ...

    varnish安装配置[归类].pdf

    它通过将频繁访问的内容存储在内存中,减少对后端服务器的请求,从而提高网站响应速度和用户体验。以下是关于Varnish 3.0.2的安装配置步骤以及关键...实际应用中,Varnish配置可以根据具体需求进行更复杂和细致的定制。

    Varnish 应用技术指南 V3.0 中文版

    2. Varnish配置:Varnish使用VCL(Varnish Configuration Language)进行配置,这是一种简洁的编程语言,允许用户定义缓存策略。通过VCL,你可以控制哪些请求应该被缓存,哪些应该直接传递到后端服务器。 3. 缓存...

    marathon-varnish:从 Mesos Marathon API 输出创建 Varnish 配置

    马拉松清漆这是从 Mesos Marathon API 创建 Varnish 配置的示例。 http://localhost:8080/v2/tasks输出将输出如下内容: { "tasks": [ { "appId": "/foo", "id": "foo.4cef049d-643e-11e4-bdcd-9cb65491f714", "host...

Global site tag (gtag.js) - Google Analytics