Nginx "ungültige Anzahl von Argumenten in "try_files" Richtlinie..." für PHP-Sicherheit

Ich versuche Nginx läuft von der Quelle in den Benutzer-Ordner von meinem shared host mit debian-style-Verzeichnis-Struktur. Ich erhalte eine Fehlermeldung, wenn ich versuche den server zu starten bis:

[emerg] invalid number of arguments in "try_files" directive in /home/.../nginx/conf/sites-enabled/default:11

Die Zeile verwiesen wird, ist die PHP-Ausführung Schutz vor den Nginx Fallstricke Seite. Hier sind meine config Dateien:

nginx.conf:

worker_processes 1;

events {
    worker_connections 1024;
}

http {

    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 65;
    types_hash_max_size 2048;
    client_max_body_size 5m;

    include /home/hittingsmoke/nginx/conf/mime.types;
    default_type application/octet-stream;

    gzip on;
    gzip_disable \"msie6\";

    include /home/hittingsmoke/nginx/conf/sites-enabled/*;
}

...und sites-available/default:

server {
    listen       12513;

    root /home/hittingsmoke/nginx/html/;
    index index.php index.html index.htm;

    server_name _;

    location ~ \.php$ {
        try_files $uri =404;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass unix:/home/hittingsmoke/php-5.3/var/run/php5-fpm.sock;
        fastcgi_param   SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_index index.php;
        include fastcgi_params;
    }
    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   html;
    }

}

Ich kann nichts finden falsch mit meinen configs. Mein setup ist fast identisch zu einer funktionierenden installation auf einem Ubuntu-box, die bei mir läuft. Was mache ich falsch?

EDIT: Nach weiteren Tests, das passiert nur, wenn ich Sie mit einem Seiten-setup zur Verfügung, die mit einem include in der nginx.conf. Wenn ich copy/paste des Inhalts meiner sites-available/default in meine nginx.conf funktioniert alles einwandfrei.

EDIT2: Wie bereits erwähnt, wenn ich entfernt try_files aus der vhosts Datei der Fehler wieder Auftritt mit den gleichen Fehler auf fastcgi_params. Hier ist der Inhalt meiner fastcgi_params-Datei. Es ist alles Standard:

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  SCRIPT_NAME        $fastcgi_script_name;
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  HTTPS              $https if_not_empty;

fastcgi_param  GATEWAY_INTERFACE  CGI/1.1;
fastcgi_param  SERVER_SOFTWARE    nginx/$nginx_version;

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;

# PHP only, required if PHP was built with --enable-force-cgi-redirect
fastcgi_param  REDIRECT_STATUS    200;

EDIT3: ich habe einen leichten Fehler. Es ist fastcgi_param, nicht fastcgi_param*s*, wo der Fehler contiunes nach dem entfernen der try_files-Richtlinie.

InformationsquelleAutor HittingSmoke | 2013-06-27
Schreibe einen Kommentar