nginx показывает пустые страницы PHP
Я настроил сервер nginx с php5-fpm. Когда я пытаюсь загрузить сайт, я получаю пустую страницу без ошибок. Html-страницы обслуживаются нормально, но не php. Я попытался включить display_errors в php.ini, но безуспешно. php5-fpm.log не выдает никаких ошибок, как и nginx.
Файл Nginx.conf
server {
listen 80;
root /home/mike/www/606club;
index index.php index.html;
server_name mikeglaz.com www.mikeglaz.com;
error_log /var/log/nginx/error.log;
location ~ \.php$ {
#fastcgi_pass 127.0.0.1:9000;
# With php5-fpm:
fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_index index.php;
include fastcgi_params;
}
}
РЕДАКТИРОВАТЬ
Вот мой журнал ошибок nginx:
2013/03/15 03:52:55 [error] 1020#0: *55 open() "/home/mike/www/606club/robots.txt" failed (2: No such file or directory), client: 199.30.20.40, server: mikeglaz.com, request: "GET /robots.txt HTTP/1.1", host: "mikeglaz.com"
14 answers
Для справки я прикрепляю свой блок location
для перехвата файлов с расширением .php
:
location ~ \.php$ {
include /path/to/fastcgi_params;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name;
}
Дважды проверьте /path/to/fastcgi-params
и убедитесь, что он присутствует и читается пользователем nginx.
Заменить
include fastcgi_params;
С
include fastcgi.conf;
И удалите имя ФАЙЛА СЦЕНАРИЯ fastcgi_param... в файле nginx.conf
Также имел эту проблему и, наконец, нашел решение здесь. Короче говоря, вам нужно добавить следующую строку в файл конфигурации nginx fastcgi (/etc/nginx/fastcgi_params в Ubuntu 12.04)
fastcgi_param PATH_TRANSLATED $document_root$fastcgi_script_name;
Многие пользователи попадают в эту тему, ожидая найти решение для отображения пустых страниц при использовании nginx+php5-fpm, и я один из них. Это краткое изложение того, что я в итоге сделал, прочитав многие ответы здесь, а также мои собственные исследования:
1) Откройте /etc/php5/fpm/pool.d/www.conf
и проверьте значение параметра location
.
location = /var/run/php5-fpm.sock
2) Параметр location
должен соответствовать параметру fastcgi_pass
в вашем файле nginx.conf
.
fastcgi_pass unix:/var/run/php5-fpm.sock;
3) Проверьте файл на самом деле существует:
$ file /var/run/php5-fpm.sock
/var/run/php5-fpm.sock: socket
4) Если он не существует, это означает, что php5-fpm не запущен, поэтому вам нужно перезапустить его:
$ sudo /etc/init.d/php5-fpm restart
[ ok ] Restarting php5-fpm (via systemctl): php5-fpm.service.
Что касается раздела location
:
location ~ \.php$ {
include fastcgi_params;
# With php5-fpm:
fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_index index.php;
}
Проверьте, существует ли файл fastcgi_params
в расположении /etc/nginx/
:
$ file /etc/nginx/fastcgi_params
/etc/nginx/fastcgi_params: ASCII text
Обычно этот файл содержит список определений переменных, требуемых php5-fpm:
fastcgi_param QUERY_STRING $query_string;
fastcgi_param REQUEST_METHOD $request_method;
...
fastcgi_param REDIRECT_STATUS 200;
Nginx включает в себя два возможных файла параметров: fastcgi_params и fastcgi.conf. разница между ними заключается в определении переменной SCRIPT_FILENAME
:
$ diff fastcgi_params fastcgi.conf
1a2
> fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
Короче говоря, fastcgi.conf всегда должен работать. Если по какой-то причине вы используете параметры fastcgi_params, вы должны определить SCRIPT_FILENAME
:
location ~ \.php$ {
include fastcgi_params;
# With php5-fpm:
fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
Теперь перезагрузите конфигурацию nginx:
$ sudo nginx -s reload
И проверьте, правильно ли отображается php-файл. Например:
/var/www/html/test.php
<pre><?php var_export($_SERVER)?></pre>
Где /var/www/html
- путь к корневому каталогу документа.
Убедитесь, что у вас есть это в /etc/nginx/fastcgi_params
Имя ФАЙЛА СЦЕНАРИЯ Fastcgi_param $имя файла запроса;
Кто знает, почему этого еще нет? Сколько времени это должно быть коллективно потрачено впустую!
Я написал короткую программу на языке Си, которая возвращает переменные среды, переданные из nginx в приложение FastCGI.
#include <stdlib.h>
#include <fcgi_stdio.h>
extern char **environ;
int main(int argc, char **argv) {
char *envvar;
int i;
int count = 0;
while(FCGI_Accept() >= 0) {
printf("Content-type: text/html\n\n"
"<html><head><title>FastCGI Call Debug Tool</title></head>\n"
"<body><h1>FastCGI Call Debugging Tool</h1>\n"
"<p>Request number %d running on host <i>%s</i></p>\n"
"<h2>Environment Variables</h2><p>\n",
++count, getenv("SERVER_NAME"));
i = 0;
envvar = environ[i];
while (envvar != NULL) {
printf("%s<br/>",envvar);
envvar = environ[++i];
}
printf("</p></body></html>\n");
}
return 0;
}
Сохраните это в файл, например fcgi_debug.c
Чтобы скомпилировать его, сначала установите gcc
и libfcgi-dev
, затем запустите:
gcc -o fcgi_debug fcgi_debug.c -lfcgi
Чтобы запустить его, установите spawn-fcgi
, затем запустите:
spawn-fcgi -p 3000 -f /path/to/fcgi_debug
Затем измените конфигурацию nginx fcgi, чтобы указать на программу отладки:
fastcgi_pass 127.0.0.1:3000;
Перезапустите nginx, обновите страницу, и вы увидите, что все параметры появятся в вашем браузере для вас, чтобы отладить! :-)
Эти подсказки помогли мне с установкой Ubuntu 14.04 LTS,
Кроме того, мне нужно было включить short_open_tag
в /etc/php5/fpm/php.ini
$ sudo kate /etc/php5/fpm/php.ini
short_open_tag = On
$ sudo service php5-fpm restart
$ sudo service nginx reload
Добавьте это в /etc/nginx/conf.d/default.conf
:
fastcgi_param PATH_TRANSLATED $document_root$fastcgi_script_name;
В случае, если у кого-то возникла эта проблема, но ни один из приведенных выше ответов не решает их проблемы, у меня была та же проблема, и мне было труднее всего отследить ее, так как мои файлы конфигурации были правильными, мои задания ngnix и php-fpm выполнялись нормально, и в журналах ошибок не было ошибок.
Глупая ошибка, но я никогда не проверял переменную Short Open Tag в моем файле php.ini, которая была установлена в short_open_tag = Off
. Поскольку мои php-файлы использовали <?
вместо <?php
, страницы были появляется пустой. В моем случае короткий открытый тег должен был иметь значение On
.
Надеюсь, это кому-то поможет.
Причина, по которой возникает эта проблема, заключается в том, что конфигурации fastcgi в nginx работают не так, как требуется, и на месте или при обработке они реагируют как данные html. Существует два возможных способа настройки nginx, чтобы избежать этой проблемы.
-
Способ 1:
location ~ \.php$ { fastcgi_split_path_info ^(.+\.php)(/.+)$; # With php5-fpm: fastcgi_pass unix:/run/php5-fpm.sock; fastcgi_index index.php; include fastcgi.conf; }
-
Способ 2:
location ~ \.php$ { fastcgi_split_path_info ^(.+\.php)(/.+)$; include snippets/fastcgi-php.conf; # With php5-fpm: fastcgi_pass unix:/var/run/php5-fpm.sock; include fastcgi_params; }
Оба метода будут работать должным образом, вы можете пойти дальше и воспользоваться любым из них. Они почти выполняют одни и те же операции с очень мало различий.
Если вы получаете пустой экран, это может быть вызвано 2 причинами:
-
Браузер блокирует отображение кадров. В некоторых браузерах фреймы считаются небезопасными. Чтобы преодолеть это, вы можете запустить бескаркасную версию phpPgAdmin с помощью
http://-your-domain-name-/intro.php
Вы включили функцию безопасности в Nginx для Параметров X-кадра попробуйте отключить ее.
Ни один из приведенных выше ответов не сработал для меня - PHP правильно отображал все, кроме страниц, которые полагались на mysqli, для которых он отправлял пустую страницу с кодом ответа 200 и не выдавал никаких ошибок. Поскольку я нахожусь на OS X, исправление было просто
sudo port install php56-mysql
С последующим перезапуском PHP-FPM и nginx.
Я переходил с более старой установки Apache/PHP на nginx и не заметил несоответствия версий в драйвере для php-mysql
и php-fpm
.
У меня была аналогичная проблема, nginx обрабатывал страницу на полпути, а затем останавливался. Ни одно из предложенных здесь решений не работало на меня. Я исправил это, изменив буферизацию nginx fastcgi:
fastcgi_max_temp_file_size 0;
fastcgi_buffer_size 4K;
fastcgi_buffers 64 4k;
После изменений мой блок location
выглядел так:
location ~ \.php$ {
try_files $uri /index.php =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_max_temp_file_size 0;
fastcgi_buffer_size 4K;
fastcgi_buffers 64 4k;
include fastcgi_params;
}
Подробнее см. https://www.namhuy.net/3120/fix-nginx-upstream-response-buffered-temporary-file-error.html
Это решило мою проблему
location ~ \.php$ {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
include snippets/fastcgi-php.conf;
# With php5-fpm:
fastcgi_pass unix:/var/run/php5-fpm.sock;
include fastcgi_params;
}