Varnish缓存实现动静分离(2)

请求到达后可以使用的VCL内建公用变量:

公用变量名称   含义  
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之前,可以使用的公用变量:

公用变量名称   含义  
beresp.request   指定请求类型,例如GET和HEAD等  
beresp.url   指定请求的地址  
beresp.proto   表示客户端发起的请求的HTTP协议版本  
beresp.http.header   表示对应请求中的HTTP头部信息  
beresp.ttl   表示缓存的生存周期,也就是cache保留多长时间,单位为秒  

从cache或后端主机获取内容后,可以使用的公用变量:

公用变量名称   含义  
obj.status   表示返回内容的请求状态代码,例如200、302和504等  
obj.cacheable   表示返回的内容是否可以缓存,也就是说,如果HTTP返回的是202、203、300、301、302、404或410等,并且有非0的生存期,则可以缓存。  
obj.valid   表示是否有效的HTTP应答  
obj.response   表示返回内容的请求状态信息  
obj.proto   表示返回内容的HTTP协议版本  
obj.ttl   表示返回内容的生存周期,也就是缓存时间,单位为秒  
obj.lastuse   表示返回上一次请求到现在的间隔时间,单位为秒  

对客户端应答时,可以使用的公用变量:

公用变量名称   含义  
resp.status   表示返回给客户端的HTTP状态代码  
resp.proto   表示返回给客户端的HTTP协议版本  
resp.http.header   表示返回给客户端的HTTP头部信息  
resp.response   表示返回给客户端的HTTP状态信息  

三、Varnish负载均衡及其动静分离实战

实验环境如下:

主机   IP   服务功能  
Varnish   10.1.10.65/16   Varnish Server   
web1   10.1.10.66/16   httpd server  
web2   10.1.10.67/16   httpd server  

注意:在实现两台后端主机负载均衡时需将此路径设置为不缓存直接从后端主机中取得数据

#
# This is an example VCL file for Varnish.
#
# It does not do anything by default, delegating control to the
# builtin VCL. The builtin VCL is called when there is no explicit
# return statement.
#
# See the VCL chapters in the Users Guide at https://www.varnish-cache.org/docs/
# and for more examples.
# Marker to tell the VCL compiler that this VCL has been adapted to the
# new 4.0 format.
vcl 4.0;
import directors; #导入directors模块
# Default backend definition. Set this to point to your content server.
probe check { #定义健康状态检测
.url = "/";    #检测的路径URL
.window = 5;    #检测次数   
.threshold = 4;  #检测次数中成功多少次才算健康 
.interval = 2s;  #两次健康状态检测之间的时间间隔 
.timeout = 1s;    #检测超时时长
}
backend websrv1 {    #添加后端主机websrv1
    .host = "10.1.10.66";  #后端主机IP地址
    .port = "80";      #后端主机监听的端口
.probe = check;                    #调用健康状态机制   
}
backend websrv2 {    #添加后端主机websrv2
    .host = "10.1.10.67";      #后端主机IP地址
    .port = "80";              #后端主机监听的端口 
.probe = check;                    #调用健康状态机制
}
sub vcl_init {  #创建后端主机组
new websrv = directors.round_robin(); #设置主机组的调度算法,有两种,另一种为random
websrv.add_backend(websrv1);  #将后端主机加入到组中
websrv.add_backend(websrv2);  #将后端主机加入到组中 
}
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.
    set req.backend_hint=websrv.backend(); #设置将请求都调度都后端主机负载均衡
if (req.url ~"(?i)^/login") {  #设置/login目录不检测缓存直接送达后端主机
return(pass);
    }
if ( req.method == "PURGE") { #自定义purge方法
return(purge);
}
}
sub vcl_purge {  #调用purge方法,返回你想返回的状态码及其信息
return(synth(200,"Pugred."));
}
sub vcl_backend_response {
    # Happens after we have read the response headers from the backend.
    #
    # Here you clean the response headers, removing silly Set-Cookie headers
    # and other mistakes your backend does.
}
sub vcl_deliver {
    # Happens when we have all the pieces we need, and are about to send the
    # response to the client.
    #
    # You can do accounting or modifying the final object here.
if (obj.hits>0) { #自定义响应报文的首部信息
set resp.http.X-Cache = "Hit via "+ server.ip;
}else {
set resp.http.X-Cache = "Miss via "+ server.ip;
}
}

配置完成后可使用varnish_reload_vcl完成编译和应用此配置,也可使用varnishadm实现,负载均衡实现图如下:

Varnish缓存实现动静分离

配置动静分离配置如下:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/248f98159e81fccd65ab73d380cbc2f3.html