PHP-FPM: nginx/error.log からの「そのようなファイルまたはディレクトリはありません」というエラー。パスまたは権限の問題ですか?

PHP-FPM: nginx/error.log からの「そのようなファイルまたはディレクトリはありません」というエラー。パスまたは権限の問題ですか?

ブラウザ バーに wiki アドレスを入力すると、「FastCGI が stderr に送信されました: 「プライマリ スクリプトを開けません: /var/www/mediawiki/index.php (そのようなファイルまたはディレクトリはありません)」」というエラーが表示されます。PHP-FPM www.conf ファイルは次のとおりです。

[www]
user = nginx
group = nginx
listen = /var/run/php/php-fpm/php-fpm.sock
listen.owner = nginx
listen.group = nginx
listen.mode = 0660
;chroot = 
;chdir = 
;env[HOSTNAME] = $HOSTNAME
;env[PATH] = /usr/local/bin:/usr/bin:/bin
;env[TMP] = /tmp
;env[TMPDIR] = /tmp
;env[TEMP] = /tmp
php_value[session.save_handler] = files
php_value[session.save_path]    = /var/lib/php/session
php_value[soap.wsdl_cache_dir]  = /var/lib/php/wsdlcache
php_value[opcache.file_cache]  = /var/lib/php/opcache

これが私の nginx conf.d ファイルです:

# HTTP requests will be redirected to HTTPS

server {
    listen 80;
    listen [::]:80;
    server_name wiki.example.com;
    return 301 https://$host$request_uri;
}

# HTTPS Configuration

server {
    listen 443 ssl;
    listen [::]:443;

    server_name wiki.example.com;
    root /var/www/mediawiki;

    index index.php;
    autoindex off;

    # SSL Certification Configuration

    ssl_certificate 
      /etc/letsencrypt/live/wiki.example.com/fullchain.pem;
    ssl_certificate_key 
      /etc/letsencrypt/live/wiki.example.com/privkey.pem;

    client_max_body_size 5m;
    client_body_timeout 60;

    location / {
    try_files $uri $uri/ @rewrite;
    }

    location @rewrite {
    rewrite ^/(.*)$ /index.php?title=$1&$args;
    }

    location ^~ /maintenance/ {
    return 403;
    }

    #PHP-FPM Configuration NGINX

    location ~ \.php$ {
    try_files $uri =404;
    fastcgi_split_path_info ^(.+\.php)(/.+)$;
    fastcgi_pass unix:/var/run/php/php-fpm/php-fpm.sock;
    fastcgi_index index.php;
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    include fastcgi_params;
    }

    location ~* \.(js|css|png|jpg|jpeg|gif|ico)$ {
    try_files $uri /index.php;
    expires max;
    log_not_found off;
}

location = /_.gif {
    expires max;
    empty_gif;
}

location ^~ 
^/(cache|includes|maintenance|languages|serialized|tests|images/deleted)/ {
    deny all;
}

location ^~ ^/(bin|docs|extensions|includes|maintenance|mw- 
config|resources|serialized|tests)/ {
    internal;
}

# Security for 'image' directory
location ~* images/.*.(html|htm|shtml|php)$ {
    allow all;
    types {}
    default_type text/plain;
}

# Security for 'image' directory
location ^~ /images/ {
    allow all;
    try_files $uri /index.php;
}

}

権限の問題か、php-fpm デーモンが冗長なファイル パスなどを探しているような気がします。次のようにして、nginx conf.d ファイル経由で FPM に絶対パスを渡してみました。

fastcgi_param SCRIPT_FILENAME /var/www/mediawiki/index.php;

役に立たなかった。正しい方向に進んでいることはわかっているのですが、それでも同じエラーが発生し、権限の問題があると思われます。次のことも試しました。

setenforce 0

しかし、これも機能しません。index.php ファイルを含むディレクトリ全体を chmod 777 にしました。

背景:

私は、新しいバージョンの PHP (7.0+) を必要とする wikimedia 拡張機能をインストールしたかったのですが、CentOS 7 の基本インストールに付属していたため、5.4 を実行していました。PHP の更新方法に詳しくなかったため、誤って yum remove php* を実行し、remi から php73 をインストールし、それを削除して、php 5.4 を再インストールし、最終的に remi-php71.repo を有効にして yum update を実行して基本パッケージを更新できることが分かりました。ただし、このプロセスで .conf ファイルと php.ini ファイルが失われました。

編集:

ブラウザで自分の Web サイトにアクセスすると、/var/log/nginx/error.log に次のログが記録されます。

2019/01/22 16:58:19 [error] 10876#0: *1 FastCGI sent in stderr: "Unable to 
open primary script: /var/www/mediawiki/index.php (No such file or 
directory)" while reading response header from upstream, client: 
10.11.190.1, server: wiki.example.com, request: "GET / HTTP/1.1", 
upstream: "fastcgi://unix:/var/run/php/php-fpm/php-fpm.sock:", host: 
"wiki.example.com"

/var/log/php-fpm/www-access.log:

- 22/Jan/2019:16:58:19 -0700 "GET /index.php" 404 
/var/www/mediawiki/index.php /var/www/mediawiki /index.php /index.php

答え1

cgi.fix_pathinfo=0クリストファーが質問に対して正しい方向を示してくれたおかげで、私はそれを修正しましたphp.ini

彼の具体的な質問では問題は解決しなかったが、私は設定をいろいろ試し続けたcgi.fix_pathinfo=0php.iniそして、PHP-FPM から、開けないというエラーメッセージは表示されず、別のエラーメッセージも表示されました/var/www/mediawiki/index.php

この問題を解決するのに丸々 5 日かかりました。Christopher さんの助力に本当に感謝しています。

私は最終的に次の行をコメントアウトしましたphp.ini:

;cgi.fixpathinfo=0
;user_dir=/var/www/mediawiki    **This is the one that changed the error message

これを変更すると、5.4 から 7.1 にアップグレードしたときにInvalidArgumentExceptionインストールしなかったために、エラーが発生しました。php-mysqlnd

それをインストールすると、Wiki が再び起動して実行されます。

建物の周りを 5 回走り回りたい気分です。正しい方向を指し示してくれた Christopher に改めて感謝します。

ヨルダン

関連情報