Varnish Cache不会使用会话缓存PHP除非后端TTL被更改

时间:2011-03-29 01:45:38

标签: php cookies varnish

我是Varnish Cache的新手并且有一个问题,希望我能得到一些帮助。

我有一个非常简单和基本的设置,但它没有按照我的理解工作 它应该出于某种原因。

这与Varnish没有缓存使用cookie的PHP页面有关。

这是我的设置:

1)对于我的default.vcl我有一个简单的后端

backend default {
.host = "127.0.0.1";
.port = "80";
}

2)我有一个简单的PHP文件,只有这两行:

session_start();
echo time();

3) 当我调用此页面时,它正确无法缓存 因为我没有添加所需的vcl规则

4)

根据我对我添加的文档的理解 在这两条规则中

sub vcl_recv {
unset req.http.Cookie;
return (lookup);
}

sub vcl_fetch {
unset beresp.http.Set-Cookie;
return(deliver);
}

5) PHP页面仍然不会缓存。 我可以看到Set-Cookie标题已经存在 因为我在FireFox中使用FireBug而删除了。

只有将其添加到sub vcl_fetch时才会这样 PHP将缓存:

set beresp.ttl = 24h;

我的问题是这是正确的吗?

我认为我不需要改变ttl 后端响应。我以为只是不安 cookie进出会强制PHP w / session缓存。

我的完整默认vcl是:

backend default {
.host = "127.0.0.1";
.port = "80";
}

sub vcl_recv {
unset req.http.Cookie;
return (lookup);
}

sub vcl_fetch {
unset beresp.http.Set-Cookie;
set beresp.ttl = 24h;
return(deliver);
}

我的启动命令是:

varnishd -f /etc/varnish/default.vcl -s malloc,128M -T 127.0.0.1:2000 -a 0.0.0.0:8080

我打电话的网址是:

http://vbox.local:8080/varnish-tests/index.php

我的index.php文件只有:

<?php 
session_start();
echo time();

我想询问社区是否正确 或者如果我错了。基本上我只是不确定为什么我有 添加beresp.ttl = 24h以最终拥有页面缓存 在清漆。

我以为我不需要这个。

任何建议都非常感谢。

谢谢!

亲切的问候。

5 个答案:

答案 0 :(得分:5)

Varnish将遵循响应中的缓存标头。 PHP将发送缓存控制头,而不是通过deafult缓存响应

Cache-Control:no-store, no-cache, must-revalidate, post-check=0, pre-check=0
Pragma:no-cache

您需要禁用这些标头,否则Varnish将遵守,因此不会缓存页面。要关闭它们,只需使用空字符串调用session_cache_limiter()

session_cache_limiter('');
header("Cache-Control: public, s-maxage=60");
session_start();

然后,您可以添加标头以将缓存控件设置为public。使用上面的三行将启用缓存。

答案 1 :(得分:4)

正如ZoFreX所说,这可能是因为你的Cache-Control或Expires标题。

另请注意,此规则有点危险:

sub vcl_recv {
    unset req.http.Cookie;
    return (lookup);
}
sub vcl_fetch {
    unset beresp.http.Set-Cookie;
    return(deliver);
}

如果您的服务器发送cookie,那可能是因为您需要它们,至少对于会话而言。 这种规则将完全禁用应用程序服务器的会话管理。

根据您使用会话的原因,您无法缓存内容的每个部分(例如:用户特定内容)。

答案 2 :(得分:1)

您应该仔细查看PHP发送给Varnish的标头(例如,通过直接访问您的服务器而不是通过varnishd)。如果标题说内容无法缓存,则不会。如果他们没有说它可以缓存,那就不会 - 而且我怀疑这就是为什么Varnish只是在你手动设置ttl时才进行缓存,因为标题没有“expires”或“max-age” ”

答案 3 :(得分:1)

获取由varnish缓存的响应的最简单方法是添加缓存控制头。

PHP:

header('Cache-Control: public, s-maxage=60');

会告诉varnish将响应缓存60秒。

答案 4 :(得分:0)

我遇到了完全相同的问题。当你执行session_start时,PHP似乎注意到页面可能是动态的,并且有助于将缓存控制头重置为:

Cache-Control:no-store, no-cache, must-revalidate, post-check=0, pre-check=0
Pragma:no-cache

Varnish的默认配置服从apache / php发送的这些缓存指令,这意味着它不会缓存这些页面。我不是100%确定可以覆盖默认配置,只是为了扩展它。

我一直在使用的解决方法是重新设置Cache-Control标头,但请注意,必须在session_start更改之后完成此操作。我没有测试过它是否也需要在session_write_close之后,但是比抱歉更安全。