Nginx 1.2.2: Як змусити файли try_files працювати?


11

Нещодавно я оновив nginx до версії 1.2.2 і, здається, наступна запис порушена; мабуть, зміна синтаксису між версіями?

location / {
                # First attempt to serve request as file, then
                # as directory, then fall back to index.html
                try_files $uri /index.html;
        }

Коли я переглядаю веб-сторінку http://www.mysite.com/a-non-existent-url, я переспрямовуюсь на сторінку помилки "500 внутрішніх помилок сервера". Зроблено наступний запис журналу;

2012/08/13 09:20:29 [error] 18457#0: *60 rewrite or internal redirection cycle 
while internally redirecting to "/index.html", client: 10.0.14.1, server: 
mysite.com, request: "GET /a-non-existent-url HTTP/1.1", host: "www.mysite.com"

Це працювало як слід, я не можу знайти правильний синтаксис для цієї версії. Як це має бути зараз?

ОНОВЛЕННЯ Повна конфігурація як запит;

server {

    root /usr/share/nginx/mysite.com/public_html;
    index index.php index.html index.htm;
    server_name mysite.com www.mysite.com;
    access_log  /usr/share/nginx/mysite.com/logs/access_log;
    error_log   /usr/share/nginx/mysite.com/logs/error_log;

    location / {
        # First attempt to serve request as file, then
        # as directory, then fall back to index.html
        try_files $uri $uri/ /index.html;
    }

    #Added for awstats
    location ^~ /awstats-icon {
            alias /usr/share/awstats/icon/;
            access_log off;
    }

    #Added for awstats
    location ^~ /awstatscss {
            alias /usr/share/doc/awstats/examples/css/;
            access_log off;
    }

    #Added for awstats
    location ^~ /awstatsclasses {
            alias /usr/share/doc/awstats/examples/classes/;                                 
            access_log off;
    }

    #Added for awstats
    # Configure /cgi-bin/scripts to go through php-fastcgi
    location ~ ^/cgi-bin/.*\.(cgi|pl|py|rb) {
            gzip off;
            fastcgi_pass  127.0.0.1:9000;
            fastcgi_index cgi-bin.php;
            fastcgi_param SCRIPT_FILENAME    /etc/nginx/cgi-bin.php;
            fastcgi_param SCRIPT_NAME        /cgi-bin/cgi-bin.php;
            fastcgi_param X_SCRIPT_FILENAME  /usr/lib$fastcgi_script_name;
            fastcgi_param X_SCRIPT_NAME      $fastcgi_script_name;
            fastcgi_param QUERY_STRING       $query_string;
            fastcgi_param REQUEST_METHOD     $request_method;
            fastcgi_param CONTENT_TYPE       $content_type;
            fastcgi_param CONTENT_LENGTH     $content_length;
            fastcgi_param GATEWAY_INTERFACE  CGI/1.1;
            fastcgi_param SERVER_SOFTWARE    nginx;
            fastcgi_param REQUEST_URI        $request_uri;
            fastcgi_param DOCUMENT_URI       $document_uri;
            fastcgi_param DOCUMENT_ROOT      $document_root;
            fastcgi_param SERVER_PROTOCOL    $server_protocol;
            fastcgi_param REMOTE_ADDR        $remote_addr;
            fastcgi_param REMOTE_PORT        $remote_port;
            fastcgi_param SERVER_ADDR        $server_addr;
            fastcgi_param SERVER_PORT        $server_port;
            fastcgi_param SERVER_NAME        $server_name;
            fastcgi_param REMOTE_USER        $remote_user;
    }

    #Make sure all PHP is process by php-fpm
    location ~ \.php$ {
        fastcgi_pass 127.0.0.1:9000;
        fastcgi_index index.php;
        include fastcgi_params;
    }

    #rTorrent/wTorrent needs this
    #To loop back to the xml rpc service
        location /RPC2 {
                scgi_pass   127.0.0.1:5000;
                include     scgi_params;
                scgi_param    SCRIPT_NAME  /RPC2;
        }

}

2-е ОНОВЛЕННЯ

Тут розміщено журнал налагодження ( http://pastebin.com/raw.php?i=PtLwvQhW ). Це досить довго, тому я зробив це, щоб уникнути спаму на цій публікації.


Покажіть повний конфігурацію.
кванта

1
Додайте debugдо кінця error_logрядка, спробуйте ще раз та опублікуйте тут журнал помилок.
кванта

Я додав посилання до відро для пасти у своєму дописі; pastebin.com/raw.php?i=PtLwvQhW
jwbensley

ls -l /usr/share/nginx/mysite.com/public_html/index.html?
кванта

Відповіді:


12

Змініть рядок try_files на:

try_files $uri $uri/ /index.html =404;

Посилання: https://nginx.org/en/docs/http/ngx_http_core_module.html#try_files


1
ОК, пару моїх дурних пунктів тут з мого боку. По-перше, index.html не існує, і це повинно бути index.php, яким він був спочатку, у мене є стара копія конфігурації, яка показує, що (просто запуск розрізнення вказало мені це). Не знаєте, як це змінилося ?! По-друге, вказівка ​​на /index.php насправді змусило мій браузер завантажити сирий php-код, який є трохи небезпечним, але вказує на / працює просто чудово. Так що зараз лінія try_files $uri $uri/ / =404;Дякую велике: D
jwbensley

2
Дуже дякую. Я видалив /index.htmlшахту, не знаючи, що try_filesвикликає внутрішнє переспрямування на останній елемент у списку, якщо жоден не відповідає. Я залишив лінію, try_files $uri $uri/ =404;яка добре працює в моєму випадку.
Дрю Ноакс
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.