Использование последней версии nginx (1.10.0) и php-fpm (PHP 7.0.6) на 64-битной архитектуре Linux.
При попытке запросить index.php для установки «ДокуВики» я получаю следующую ошибку:
2016/05/21 22:09:50 [error] 11099#11099: *1 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: 192.168.70.3, server: doku.test.com, request: "GET /install.php HTTP/1.1", upstream: "fastcgi://unix:/run/php-fpm/php-fpm.sock:", host: "doku.test.com"
Вот соответствующая конфигурация сервера:
server {
listen 80;
server_name doku.test.com;
root /var/www/doku/public_html/;
access_log /var/log/nginx/scripts.log scripts;
location ~ \.php$ {
include fastcgi_params;
fastcgi_pass unix:/run/php-fpm/php-fpm.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
}
Вот fastcgi_params:
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 REQUEST_SCHEME $scheme;
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;
Как видно из конфигурации моего сервера, я пытаюсь зарегистрировать вывод SCRIPT_FILENAME
параметр, поскольку все мои исследования, кажется, указывают на это как на виноватую. Вот соответствующая часть nginx.conf:
log_format scripts '$document_root$fastcgi_script_name > $request';
При запросе страницы index.php ниже создается в scripts.log
:
/var/www/doku/public_html/index.php > GET /index.php HTTP/1.1
Выполнение ls для этого файла:
-rwxr-xr-x 1 nginx nginx 182 May 21 06:45 /var/www/doku/public_html/index.php
Стоит отметить, что и демон nginx, и демон php-fpm настроены для запуска от имени пользователя nginx с использованием группы nginx. Я не понимаю, почему я получаю начальную ошибку, поскольку регистрация эффективно доказала, что SCRIPT_FILENAME
действительно указывает правильный путь.
Из всех ответов ServerFault, которые я рассмотрел, добавление этого параметра в конфигурацию сервера, казалось, было решением №1 для моей ошибки, но, похоже, в моем случае это не исправляет.
Какие-либо предложения?
Сначала проверьте, правильно ли вы установили адрес прослушивания в своем www.conf
файл для PHP-FPM (FastCGI Process Manager). Так открыто www.conf
файл (расположение: /etc/php5/fpm/pool.d/www.conf
), и он должен увидеть что-то вроде этого:
Start a new pool named 'www'.
[www]
;prefix = /path/to/pools/$pool
user = www-data
group = www-data
listen = 127.0.0.1:8080
; Set permissions for unix socket, if one is used. In Linux, read/write
; permissions must be set in order to allow connections from a web server. Many
; BSD-derived systems allow connections regardless of permissions.
; Default Values: user and group are set as the running user
; mode is set to 0660
listen.owner = www-data
listen.group = www-data
listen.mode = 0660
Под адресом прослушивания проверьте, установили ли вы адрес обратной связи (он идентифицирует ваш сервер) и номер порта. Тогда в вашем nginx.conf
изменение файла fastcgi_pass
к 127.0.0.1:8080
, поэтому в итоге должно получиться так:
server {
listen 80;
server_name doku.test.com;
root /var/www/doku/public_html/;
access_log /var/log/nginx/scripts.log scripts;
location ~ \.php$ {
include fastcgi_params;
fastcgi_pass 127.0.0.1:8080;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
}
Обратите внимание, что в примере я использовал порт 8080, возможно, вам придется его изменить.