清漆4,清洗 - 我以为我已经弄明白了

alt*_*ric 6 caching varnish varnish-vcl

好吧,我会保持简单,PURGE请求(或者我认为?)几乎全部由字面处理:

acl purge {

    "localhost";

    "127.0.0.1";

}
Run Code Online (Sandbox Code Playgroud)

然后

if (req.method == "PURGE") {
            if (!client.ip ~ purge) {
            return(synth(405, "This IP is not allowed to send PURGE requests."));
            }
            return (purge);
    }
Run Code Online (Sandbox Code Playgroud)

我相当肯定上述两个陈述都是"正确的",我挂断的是如果我发送了一个

curl -X PURGE http://domain.com/
Run Code Online (Sandbox Code Playgroud)

要么

curl -X PURGE http://domain.com/.*

和Varnish发回200 Purged well ...缓存被清除了?即使它只是主页而不是整个缓存(发誓它都是使用上面的.*方法)并且上面的代码片段是正确的有任何特殊原因http://domain.com(如在实际的主页中) )没有被清除?

varnishncsa显示:

MYIP - - [16/Feb/2015:23:23:10 -0600] "PURGE http://domain.com/ HTTP/1.1" 200 241 "-" "curl/7.29.0"
Run Code Online (Sandbox Code Playgroud)

我知道我得失去一些愚蠢的东西,但我无法弄明白吗?

小智 2

官方文档基本上说明了你所做的事情,但是请记住PURGE != BAN,你可以在BAN中使用正则表达式,但不能在PURGE中使用。使用 PURGE,您可以删除一个特定 url 的所有 Vary 定义的副本。

在我对 4.0.2 的测试中,它按照建议工作,我缓存了主页,我做了一个,curl -X PURGE http://localhost:8080/在 varnishlog 中我看到了(除其他外):

*   << Request  >> 65542     
-   Begin          req 65541 rxreq
-   Timestamp      Start: 1424188792.108573 0.000000 0.000000
-   Timestamp      Req: 1424188792.108573 0.000000 0.000000
-   ReqStart       ::1 60496
-   ReqMethod      PURGE
-   ReqURL         /

-   VCL_acl        MATCH purge "localhost"
-   VCL_return     purge
-   VCL_call       HASH
-   VCL_return     lookup
-   VCL_call       PURGE
Run Code Online (Sandbox Code Playgroud)

重新加载时,我看到 MISS & 后端请求(因为它不在缓存中):

*   << BeReq    >> 65548     
-   Begin          bereq 65547 fetch
-   Timestamp      Start: 1424188815.112540 0.000000 0.000000
-   BereqMethod    GET
-   BereqURL       /
-   BereqProtocol  HTTP/1.1

-   VCL_call       BACKEND_RESPONSE
-   TTL            VCL 120 21600 0 1424188815
-   VCL_return     deliver

*   << Request  >> 65547     
-   Begin          req 65546 rxreq

-   ReqMethod      GET
-   ReqURL         /

-   VCL_return     hash
-   VCL_call       HASH
-   VCL_return     lookup
-   Debug          "XXXX MISS"
-   VCL_call       MISS
-   VCL_return     fetch
-   Link           bereq 65548 fetch
Run Code Online (Sandbox Code Playgroud)

顺便说一句,将“::1”添加到清除 acl 中的 ip 列表中,以防您使用 ipv6。它会返回 405,但谁知道呢。