FastCGI: NGinx および PHP-FPM でプライマリ スクリプトを開けません

FastCGI: NGinx および PHP-FPM でプライマリ スクリプトを開けません

どうやらこの問題を抱えているのは私だけではないようですが、カップル向けに提案されたあらゆる解決策を試した後、何をしたらよいのかわからなくなってしまいました。

Ubuntu 16.04、NGinx、PHP-FPM を実行しています。

nginx.conf はデフォルトのものであり、より情報量の多いログ形式のみを設定しています。

ユーザー権限は問題ないようです。NGinx と PHP_FPM はユーザー www-data で実行されます。ドキュメント ルートの所有者は www-data です。FPM プールの所有者は www-data です。ソケット ファイルが存在し、書き込み可能です。

フォルダーとファイルのアクセス許可を最も弱い (chmod 777) に設定してみましたが、結果は得られませんでした。

これは私の server.conf です。コメント行からわかるように、私はさまざまなトリックを試しましたが、効果はありませんでした。

server {
    listen         8080;
#    listen         8080 default_server;
 #   listen         [::]:8080 default_server;
    server_name    example.com www.example.com
    root           /var/www/nginx/;
    index          index.php;
        access_log /var/log/nginx/scripts.log scripts;


    gzip             on;
    gzip_comp_level  3;
    gzip_types       text/plain text/css application/javascript image/*;

    location ~ \.php$ {
        if ($uri !~ "^/uploads/") {
            fastcgi_pass unix:/run/php/php-fpm-www.sock;

        }

    include fastcgi.conf;

#    include         snippets/fastcgi-php.conf;
    include         fastcgi_params;
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    fastcgi_param SCRIPT_NAME $fastcgi_script_name;

  }

    # Block access to .htaccess
    location ~ \.htaccess {
        deny all;
    }

}    

これが fpm-pool の設定です:

[www]
listen = /run/php/php-fpm-$pool.sock
user = www-data
group = www-data
listen.owner = www-data
listen.group = www-data
php_admin_flag[allow_url_fopen] = off
php_admin_flag[allow_url_include] = off
php_admin_value[memory_limit] = 128M
pm = dynamic
pm.max_children = 5
pm.start_servers = 1
pm.min_spare_servers = 1
pm.max_spare_servers = 3
chdir = /
chroot = /var/www/nginx/
php_flag[display_errors] = on
php_admin_value[error_log] = /var/log/fpm-php.www.log
php_admin_flag[log_errors] = on
catch_workers_output = yes

これは nginx の access.log の出力です:

/var/www/nginx/index.php > GET /index.php HTTP/1.1

これが実際の error.log です:

2018/08/29 17:34:27 [error] 24020#24020: *47 FastCGI sent in stderr: "Unable to open primary script: /var/www/nginx/index.php (No such file or directory)" while reading response header from upstream, client: 213.61.37.18, server: example.com, request: "GET /index.php HTTP/1.1", upstream: "fastcgi://unix:/run/php/php-fpm-www.sock:", host: "example.com:8080"

答え1

@michael のヒントのおかげで、自分でエラーを見つけました。ご指摘ありがとうございます。

私はchrootを使用しています。目的は、すべてのウェブサイトを独自の「監禁」することだからです。環境/フォルダです。このフォルダのルートを環境実際のファイルシステムの場所へ/var/www/nginx

NGinx のサーバー構成内で、先頭に $document_root を付けた fastcgi パラメータ SCRIPT_FILENAME を渡します。

fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

NGinxでは、$document_rootはルートディレクティブを参照します。$document_rootは、もちろん/var/www/nginx

しかしPHP-環境「ルートが変更されました」(/ は /var/www/nginx を意味します)。つまり、PHP は現在、フォルダー /var/www/nginx で index.php を検索しています。ただし、ルート フォルダーは「仮想」であるため、PHP の /var/www/nginx は、実際のファイル システム上のこの場所を指します: /var/www/nginx/var/www/nginx。

したがって、パラメータをこれに変更するとエラーが修正されます。

fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;

関連情報