NGINX下默认配置中的BUG

今天测试网站,遇到一个奇怪的问题:页面上的一个图片不能显示,而window系统的服务器上是正常的。

本地环境为ubuntu11.10+nginx+phpfpm+php5.

检查图片也是存在的。于是打开/var/log/nginx/error.log,看到这么一句话:

[error] 1493#0: *50 rewrite or internal redirection cycle while internal redirect to "/index.html"

这似乎与图片不显示无关。仔细检查后发现,图片名中一个字母X大小写错误,那么,这里怎么会返回500错误呢?

万能的google帮我找到了问题的根源:

Bug#643925: [nginx] rewrite or internal redirection cycle instead 404

配置过nginx的同学都知道,nginx中server配置下有一项

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

问题就出在这里,当nginx收到不存在的文件时,将试图以 目录方式 ,目录/index.html来解析文件。

但这样仍然是文件不存在,回来还要这样解析,这样就是错误中的redirection cycle(重定向循环)了。

解决办法是在server中加上如下一段

server { 
    ... 
    location /index.html { 
        rewrite ^ /index.html break; 
    } 
    ... 
} 
先来判断如果是index.html方式的请求,就不再循环解析了,这样,不存在的文件就直接返回404错误了.