Inu*_*huk 8 varnish varnish-vcl
我希望能够在Varnish 4的重试中更改后端.我们已经使用Varnish 3在不同的(较旧的)应用程序上工作,但我无法弄清楚v4,也没有找到很多文档.我们想要的设置是拥有2组导向器 - 一个用于尝试与varnish在同一数据中心中的本地服务器的初始请求,因为这样更快,然后只有在失败的情况下,从其他导向器中随机选择其他导向器.数据中心.
在第3版中,这很简单:
sub vcl_recv {
if (req.restarts == 0) {
set req.backend = defaultdirector;
} else {
set req.backend = backupdirector;
}
}
#Then in vcl_fetch and/or vcl_error something like:
if (beresp.status >= 500 && req.restarts < some_max) {
return(restart);
}
Run Code Online (Sandbox Code Playgroud)
但是现在在v4中,重启已经被替换为重试,整个文档是:
在3.0中,可以在注意到后端响应错误后返回(重启),以更改为不同的后端.
现在称为return(重试),并跳转回vcl_backend_fetch.
这只影响后端获取线程,客户端处理不受影响.
然而,我仍然看到一些人的示例代码包含return(重新启动)而不是return(重试),而不是使用retry命令的单个示例.
我知道清漆不应该再次在vcl_recv中完成所有工作(例如剥离cookie),因为它只是与后端的通信失败了,所以反弹到后端获取而不是重做是有意义的所有前端处理,但如果我尝试更改vcl_backend_fetch中的后端,我会收到编译错误.我该如何工作?
在官方文档是一种误导.实际上,重启仍然存在:您可以使用req.backend_hint在vcl_deliver中捕获错误并在vcl_recv中相应地设置后端:
sub vcl_recv {
if (req.restarts == 0) {
set req.backend_hint = defaultdirector.backend();
} else {
set req.backend_hint = backupdirector.backend();
}
}
sub vcl_deliver {
if (resp.status >= 500 && req.restarts < some_max) {
return(restart);
}
}
Run Code Online (Sandbox Code Playgroud)
或者,如果它更合适,您可以在vcl_backend_response和vcl_backend_fetch之间使用重试:
sub vcl_backend_fetch {
if (bereq.retries > 0) {
set bereq.backend = backupdirector.backend();
}
}
sub vcl_backend_response {
if (beresp.status >= 500 && bereq.retries < some_max) {
return(retry);
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3759 次 |
| 最近记录: |