当前位置:  开发笔记 > 编程语言 > 正文

nginx:使用try_files指令禁用单个文件的缓存

如何解决《nginx:使用try_files指令禁用单个文件的缓存》经验,为你挑选了2个好方法。

我使用位置部分以这种方式使用nginx为Angular 2应用程序提供服务:

location / {
  try_files $uri $uri/ /index.html =404;
}

try_files指令尝试在根目录中查找请求的uri,如果找不到它,则只返回index.html

如何禁用index.html文件的缓存?



1> Rem..:

使用nginx命名位置找到解决方案:

location / {
    gzip_static on;
    try_files $uri @index;
}

location @index {
    add_header Cache-Control no-cache;
    expires 0;
    try_files /index.html =404;
}


此配置不完全有效.在location /中,try_files将首先匹配$ uri,在没有命名位置的情况下命中index.html.所以如果你访问/,你会点击缓存.但是如果你访问/ something/else,最终命中index.html,将发送缓存控制头.
这是正确的解决方案Dmitry的解决方案只适用于规范网址,如果用户从像/ foo /这样的网址访问,它将提供index.html,但没有过期..

2> Simon Ness..:

感谢您的好评,雷姆!正如何世明指出的那样,在接受根目录(例如www.example.com/)时不会添加缓存头,但是在访问任何深层链接(例如www.example.com/some/path)时都不会添加缓存头。

经过大量的挖掘,我相信这是由于ngnix模块ngx_http_index_module的默认行为所致,默认情况下它包含index.html,因此在访问根目录/时,满足了第一个位置块的规则,并且没有使用缓存控制标头。我使用的解决方法是在第一个位置块中包含一个index指令而不指定index.html,从而强制从第二个位置块提供根/服务。

我还遇到另一个问题,我在第一个位置块中包含了根指令,该指令破坏了深层链接,也是一个坏主意。我将根指令移至服务器级别。

希望这会有所帮助,这是我的解决方案...

server {
  listen       80;
  server_name  localhost;
  root   /usr/share/nginx/html;

  location / {
    add_header X-debug-whats-going-on 1;
    index do-not-use-me.html;
    try_files $uri @index;                 
  }

  location @index {
    add_header X-debug-whats-going-on 2;
    add_header Cache-Control no-cache;
    expires 0;
    try_files /index.html =404;
  }
}

我提供了调试标头,以帮助使其绝对清楚哪个位置块正在提供哪些内容。还要注意add_header指令的不直观行为,如果您还打算向位置块外部的所有请求添加标头,则必须阅读。


调试标头的道具,显示了调试方法以及解决方案。教男人钓鱼和所有...
推荐阅读
牛尾巴2010
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有