Caching Nginx缓存状态标头不存在';即使fastcgi\U缓存也不能工作

Caching Nginx缓存状态标头不存在';即使fastcgi\U缓存也不能工作,caching,nginx,response-headers,Caching,Nginx,Response Headers,我在Ubuntu12.04上安装了Nginx1.4.1和PHP5.5.7。Nginx是用必要的额外代码编译的。我已经设置了fastcgi_缓存,并安装了Wordpress作为测试站点。我“我也使用可湿性粉剂。为了调试,我已经将配置精简到了基本的配置。fastcgi_缓存似乎正在工作,因为我创建了一个输出时间的php文件,并从CURL中多次调用它,每次都显示相同的输出。缓存位置也充满了文件,当我清除它时会清空 不起作用的是“add_header X-Cache$upstream_Cache_sta

我在Ubuntu12.04上安装了Nginx1.4.1和PHP5.5.7。Nginx是用必要的额外代码编译的。我已经设置了fastcgi_缓存,并安装了Wordpress作为测试站点。我“我也使用可湿性粉剂。为了调试,我已经将配置精简到了基本的配置。fastcgi_缓存似乎正在工作,因为我创建了一个输出时间的php文件,并从CURL中多次调用它,每次都显示相同的输出。缓存位置也充满了文件,当我清除它时会清空

不起作用的是“add_header X-Cache$upstream_Cache_status”;当添加到nginx.conf的HTTP块时,它应该添加“X-Cache=命中或未命中,或绕过或其他。我根本无法让它出现。我已经检查了我知道正在使用此缓存的其他服务器,并且确实显示了标头。我可以继续,只是忽略它,但我想知道为什么有些东西不起作用,以防更多的事情发生,以免它回来咬我

我想这可能是一个真正的错误,但我还没有找到任何参考。关于这方面的信息很少,所以我求助于智囊团——有什么想法吗?下面是配置文件。仅供参考,我尝试将add_标题行放在服务器块和位置块中,只是为了确保-没有乐趣

example.com.vhost

fastcgi_cache_path /etc/nginx/cache levels=1:2 keys_zone=MYAPP:100m inactive=60m;
fastcgi_cache_key "$scheme$request_method$host$request_uri";

add_header X-Cache $upstream_cache_status;

server {
    listen   80;
    server_name ~^(?:www\.)?(?P<example.com>.+)$ ;
    root /srv/www/$domain/htdocs;
    index index.php

    server_name example.com;


    location / {
        try_files $uri $uri/ /index.html;

    }

    location ~ \.php$ {
        try_files $uri =404;
        fastcgi_pass unix:/var/run/php5-fpm.sock;
        fastcgi_index index.php;
        include fastcgi_params;
        fastcgi_cache MYAPP;
        fastcgi_cache_valid 200 60m;
    }
}

您希望在请求中的何处设置“X-Cache”?阅读相关文档,$upstream_cache_status的内容只有在请求被传递到后端之后才可用,而不是像您尝试做的那样。我很不好意思地说,经过一段时间的睡眠后,我意识到我的错误,这只是一些愚蠢的事情(与代码无关)。对于其他遇到此问题的人来说,“add_header X-Cache$upstream_Cache_status;”放置在HTTP块中时应该可以正常工作。太多的深夜试图学习新东西,对不起。谢谢你的回复,Danack,这让我想到了另一个方向。我不知道如何处理这个例子中的问题,所以你把它放在nginx.conf的http部分?难道不能将其添加到单个vhost配置上吗?
user www-data;
worker_processes 4;
pid /var/run/nginx.pid;

events {
    worker_connections 768;
    # multi_accept on;
}

http {

    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 65;
    types_hash_max_size 2048;
    # server_tokens off;


    include /etc/nginx/mime.types;
    default_type application/octet-stream;

    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;

    gzip on;
    gzip_disable "msie6";

    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
}