簡體   English   中英

使用cURL PHP和命令行cURL進行Varnish緩存清除

[英]Varnish Cache Purging with cURL PHP vs. Command Line cURL

目前,我們在一台服務器上有多個虛擬主機。 我正在嘗試通過不涉及exec命令的PHP進行緩存清除。 我可以通過發出以下命令行命令來清除Varnish Cache中的單個文件:

curl -X PURGE -H "Host: domain.com" http://127.0.0.1/test.html

我正在嘗試將此命令復制到PHP。 我生成了以下內容:

if (isset($_POST['PurgeURL']))
{
    $purgeurl = $_POST["PurgeURL"];
    $varnishurl = "http://127.0.0.1" . $purgeurl ;
    $varnishhost = 'Host: ' . $_SERVER['SERVER_NAME'];
    $varnishcommand = "PURGE";
    $curl = curl_init($varnishurl);
    curl_setopt($curl, CURLOPT_CUSTOMREQUEST, $varnishcommand);
    curl_setopt($curl, CURLOPT_ENCODING, $varnishhost);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, false);
    $result = curl_exec($curl);
    curl_close($curl);

我正在發布/test.html

我收到以下答復:

Error 200 Purged.

Purged.

Guru Meditation:

XID: 1728013370

Varnish cache server

但是,此文件不會清除。 有任何想法嗎?

這是請求的清漆日志:

    0 Debug        - "VCL_error(200, Purged.)"
   28 SessionOpen  c 127.0.0.1 54437 :80
   28 ReqStart     c 127.0.0.1 54437 1728228985
   28 RxRequest    c PURGE
   28 RxURL        c /test.html
   28 RxProtocol   c HTTP/1.1
   28 RxHeader     c Host: 127.0.0.1
   28 RxHeader     c Accept: */*
   28 RxHeader     c Accept-Encoding: Host: domain.com
   28 VCL_call     c recv
   28 VCL_acl      c MATCH purge localhost
   28 VCL_return   c lookup
   28 VCL_call     c hash
   28 Hash         c /test.html
   28 Hash         c 127.0.0.1
   28 VCL_return   c hash
   28 VCL_call     c miss error
   28 VCL_call     c error deliver
   28 VCL_call     c deliver deliver
   28 TxProtocol   c HTTP/1.1
   28 TxStatus     c 200
   28 TxResponse   c Purged.
   28 TxHeader     c Server: Varnish
   28 TxHeader     c Content-Type: text/html; charset=utf-8
   28 TxHeader     c Retry-After: 5
   28 TxHeader     c Content-Length: 383
   28 TxHeader     c Accept-Ranges: bytes
   28 TxHeader     c Date: Wed, 08 Jan 2014 14:42:33 GMT
   28 TxHeader     c X-Varnish: 1728228985
   28 TxHeader     c Age: 0
   28 TxHeader     c Via: 1.1 varnish
   28 TxHeader     c Connection: close
   28 Length       c 383
   28 ReqEnd       c 1728228985 1389192153.441481352 1389192153.441616535 0.000058413 0.000074863 0.000060320
   28 SessionClose c error
   28 StatSess     c 127.0.0.1 54437 0 1 1 0 0 0 245 383

您沒有發出正確的“ Host:” HTTP標頭,因此我認為以下幾行之一存在問題:

$varnishhost = 'Host: ' . $_SERVER['SERVER_NAME'];

curl_setopt($curl, CURLOPT_ENCODING, $varnishhost);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM