我正在尝试建立一个基本的工作Nginx+SSI示例:
Nginx配置(只是相关部分,为了简洁起见):
ssi on;
proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:20m max_size=20m inactive=60m use_temp_path=off;
server {
listen 80;
server_name localhost;
location / {
proxy_cache my_cache;
proxy_set_header Host $host;
proxy_http_version 1.1;
proxy_buffering on;
proxy_pass http://127.0.0.1:81;
}
}
server {
listen 81;
root /path/to/root;
location ~ ^/.+\.php {
fastcgi_pass 127.0.0.1:9000;
}
}ssi.php:
<?php
header('Cache-Control: public, s-maxage=5');
?>
Time: <?php echo time(); ?>
Fragment time: <!--# include virtual="/time.php" -->time.php:
<?php
header('Cache-Control: no-cache');
echo time();include工作得很好:
时间: 1466710388片段时间: 1466710388
现在,过了一会儿,我希望页面(ssi.php)仍然被缓存,但是time.php片段是新鲜的:
时间: 1466710388片段时间: 1466710389
但是,它在5秒内完全保持不变,之后ssi页面将与片段一起更新:
时间: 1466710393片段时间: 1466710393
我以前用ESI和Varnish做过这件事,并且期望这在SSI中也是一样的。我猜错了吗?我无法在网上找到这个问题的答案,并且尝试了不同的缓存控制头,但我确信这是正确的方法。我在这里错过了什么?
发布于 2016-06-27 15:08:07
您的配置中有一个问题:您在两个服务器上启用了SSI,原因是
ssi on;在http{}级别定义。这将导致在第二个服务器{}中展开SSI指令。第一个服务器中缓存的响应中没有任何SSI指令(已经展开了),因此它始终保持不变。
如果您希望包含的片段对每个请求都是新鲜的,则必须只在第一个服务器中启用SSI,例如:
proxy_cache_path /path/to/cache keys_zone=my_cache:20m;
server {
listen 80;
server_name first.example.com;
location / {
proxy_pass http://127.0.0.1:81;
proxy_cache my_cache;
ssi on;
}
}
server {
listen 81;
server_name second.example.com;
location ~ ^/.+\.php {
fastcgi_pass 127.0.0.1:9000;
}
}请注意,ssi on与proxy_cache my_cache一起位于第一台服务器中。这样,nginx将缓存带有SSI指令的后端响应,并在每个请求上重新执行SSI处理,如果需要,缓存将单独包含。
发布于 2016-06-25 21:13:41
您只需将one string用于等价缓存或不缓存,则需要创建测试页,加载php进程以获得生成页面,大约2秒。并输出图像和其他静态内容.
附注:结果不相关,因为服务器请求脚本并设置标头。
https://stackoverflow.com/questions/38000435
复制相似问题