NGINX:设置X-Accel-Expires时缓存

前端之家收集整理的这篇文章主要介绍了NGINX:设置X-Accel-Expires时缓存前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我在静态内容和Last-Modified标头上添加了一个X-Accel-Expires标头.
我想知道什么是正确的设置来缓存这些元素而不缓存其他任何东西.

这是我目前所拥有的,但它没有缓存任何东西:

http {
include       /etc/Nginx/mime.types;

access_log  /var/log/Nginx/access.log;

sendfile        on;
client_max_body_size 2000m; 
keepalive_timeout  65;
tcp_nodelay        on;

gzip  on;
gzip_disable "MSIE [1-6]\.(?!.*SV1)";

include /etc/Nginx/conf.d/*.conf;
include /etc/Nginx/sites-enabled/*;

ssl_certificate /etc/Nginx/chain.pem; 
ssl_certificate_key /etc/Nginx/key.key;

proxy_cache_path /var/lib/Nginx/cache levels=1:2 keys_zone=cache:30m max_size=1G;
proxy_temp_path /var/lib/Nginx/proxy 1 2;
proxy_cache_use_stale error timeout invalid_header http_502;

server {
    listen       80;
    server_name domain;

    location / {
        proxy_pass http://127.0.0.1:8080;
        proxy_set_header  X-Real-IP  $remote_addr;
        proxy_read_timeout 700;
        proxy_set_header Host $http_host;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}
最佳答案
要缓存内容,首先需要在http上下文中创建一个proxy cache path,如下所示:

proxy_cache_path    /var/cache/Nginx/site1    levels=1:2    keys_zone=site1:10m max_size=1G;

然后,您还可以选择定义proxy cache key.任何具有与缓存条目相同的缓存密钥的请求都将收到缓存的答复(如果有).但默认可能已经足够好了,所以,这完全是可选的.

然后要在给定的上下文中启用缓存,只需提及应使用哪个缓存,如下所示:

proxy_cache    site1;

根据proxy cache valid指令的描述,Nginx已经尊重X-Accel-Expires并对其采取行动,你基本上已经完成了这一点.由于您不想缓存任何不包含X-Accel-Expires的内容,因此您可能希望将值0添加为默认有效时间(在内容中设置X-Accel-Expires应覆盖此默认值).

proxy_cache_valid    0m;

我认为除了没有任何缓存之外,您的配置文件在其他方面是有效的,并且您的代理本身已经有效.

然后,基本上,您需要做的就是修改配置,将以下内容添加到您的http,服务器或位置上下文中:

proxy_cache    cache;
proxy_cache_valid    0m;

(此外,您可能希望确保缓存路径存在且具有正确的权限.)

关于上面提到的habrahabr文章/示例,我认为在缓存键中包含$http_if_modified_since实际上并不正确,因为您可能最终会得到大量的多缓存条目,从而有效地浪费了缓存.

另请注意,Nginx可能不会代理X-Accel-Expires标头 – 它只在内部使用它,而IIRC可能无法向前提供此标头.要改变这种行为,你必须明确要求它被代理(如果你想通过Nginx调试你的内容,看看你的应用程序如何设置标题等):

proxy_pass_header "X-Accel-Expires";

猜你在找的Nginx相关文章