gpt4 book ai didi

varnish - Varnish 在 MISS 上的行为

转载 作者:行者123 更新时间:2023-12-04 21:19:45 24 4
gpt4 key购买 nike

考虑这个场景:
Varnish 缓存有一个 MISS,后端服务器现在正在重新生成请求的内容。在生成期间,第二个请求进入并得到一个 MISS。当另一个请求未决时,varnish 是否将此请求发送到后端?如果这一次之间出现了数千个请求怎么办。服务器会崩溃吧?每一个请求都会让它变慢。

这是正确的还是 Varnish “同步”这些场景以防止出现此类问题?

先感谢您!

最佳答案

Varnish 将所有请求发送到后端。 IE。它不会对其他请求进行排队,只发出一个后端请求,并将其响应用于所有请求。

然而 Varnish 有一个 grace option这让您可以在缓存中为这些类型的情况保留旧的、过期的内容。

例如,考虑以下 VCL:

sub vcl_recv {
if (req.backend.healthy) {
set req.grace = 5m;
} else {
set req.grace = 24h;
}
}

sub vcl_fetch {
set beresp.grace = 24h;
}

现在,如果后端是健康的(参见 backend polling )并且请求结果是 MISS ,第一个请求被发送到后端。如果另一个请求针对相同的内容,但缓存中有一个年龄 MISS,就会发生这种情况。从后端获取响应(并且缓存再次刷新)或项目的年龄变得大于 TTL+req.grace。

如果后端关闭(req.backend.healthy == FALSE),只要 age
您可能还想查看 Saving a request Varnish book的部分更全面的例子和练习。

固定:未转义 < 字符。

修复更多:还有另一个未转义的 < 字符...

关于varnish - Varnish 在 MISS 上的行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14580491/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com