我正在尝试缓存静态内容,这些内容基本上位于虚拟服务器配置中的下面路径中。由于某种原因,文件未被缓存。我在缓存目录中看到了几个文件夹和文件,但它总是像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;
}
}
答案 0 :(得分:41)
确保您的后端不会返回Set-Cookie
标题。如果Nginx看到它,它会禁用缓存。
如果是这种情况,最好的选择是修复后端。在修复后端不是一个选项时,可以指示Nginx忽略Set-Cookie
标题
proxy_ignore_headers "Set-Cookie";
proxy_hide_header "Set-Cookie";
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;
}
}