nginx作为缓存代理不缓存任何东西

时间:2012-02-10 16:07:31

标签: linux caching proxy nginx reverse-proxy

我正在尝试缓存静态内容,这些内容基本上位于虚拟服务器配置中的下面路径中。由于某种原因,文件未被缓存。我在缓存目录中看到了几个文件夹和文件,但它总是像20mb那样不高不低。如果它是缓存图像,例如将占用至少500mb的空间。

这是nginx.conf缓存部分:

** nginx.conf **
proxy_cache_path /usr/share/nginx/www/cache levels=1:2 keys_zone=static$
proxy_temp_path /usr/share/nginx/www/tmp;
proxy_read_timeout 300s;

这是默认的虚拟服务器。

**sites-available/default**
server {
    listen   80; 

    root /usr/share/nginx/www;
    server_name myserver;
    access_log /var/log/nginx/myserver.log main;
    error_log /var/log/nginx/error.log;

    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

    location ~* ^/(thumbs|images|css|js|pubimg)/(.*)$ {
            proxy_pass http://backend;
            proxy_cache static;
            proxy_cache_min_uses 1;
            proxy_cache_valid 200 301 302 120m;
            proxy_cache_valid 404 1m;
            expires max;
    }

    location / {
            proxy_pass http://backend;
    }
}

4 个答案:

答案 0 :(得分:41)

确保您的后端不会返回Set-Cookie标题。如果Nginx看到它,它会禁用缓存。

如果是这种情况,最好的选择是修复后端。在修复后端不是一个选项时,可以指示Nginx忽略Set-Cookie标题

proxy_ignore_headers "Set-Cookie";
proxy_hide_header "Set-Cookie";

请参阅documentation

proxy_ignore_header将确保缓存发生。 proxy_hide_header将确保Cookie有效负载不包含在缓存的有效负载中。这对于避免通过NGINX缓存泄漏cookie非常重要。

答案 1 :(得分:12)

我想补充一点,多个配置选项和组合可以禁用Nginx中的代理缓存。不幸的是,这个记录很少。

在我的配置中,我设置了proxy_buffering on,并按预期启用了缓存。

答案 2 :(得分:0)

对于它的价值,我的经验是nginx并不总是将你告诉它的东西缓存。

例如,在centos7上,使用配置选项

proxy_cache_path /tmp/my_nginx_cache levels=1:2 keys_zone=my_zone:10m inactive=24h max_size=1g;

nginx实际上将文件缓存在:

/tmp/systemd-private-phJlfG/tmp/my_nginx_cache

答案 3 :(得分:0)

经过多个答案和评论后,我发现这个配置最终有效:

10m = 10mb密钥缓存,max_size到2GB,非活动= 120m(在非活动120分钟后从源刷新),use_temp_path = off(减少io)

proxy_cache_valid - 缓存状态为200和302,持续60分钟

proxy_cache_path /tmp/cache levels=1:2 keys_zone=default_cache:10m max_size=2g
                 inactive=120m use_temp_path=off;
proxy_cache_key "$scheme$request_method$host$request_uri";
proxy_cache_valid 200 302 60m;

server {
    listen       80;
    server_name  example.com;

    # https://www.nginx.com/blog/nginx-caching-guide
    location / {
        proxy_cache default_cache;
        proxy_buffering on;
        proxy_ignore_headers Expires;
        proxy_ignore_headers X-Accel-Expires;
        proxy_ignore_headers Cache-Control;
        proxy_ignore_headers Set-Cookie;

        proxy_hide_header X-Accel-Expires;
        proxy_hide_header Expires;
        proxy_hide_header Cache-Control;
        proxy_hide_header Pragma;

        add_header X-Proxy-Cache $upstream_cache_status;
        proxy_pass http://ip-of-host:80;

        #set            $memcached_key "$uri?$args";
        #memcached_pass 127.0.0.1:11211;
        # error_page     404 502 504 = @fallback;
    }
}