Здравствуйте!
Пытаюсь настроить Nginx на виртуальном хостинге так, чтобы выполнялись php-стрипты. Статика отдается нормально, а результат работы php-нет. Нагрузки на сервер нет никакой.
Исходные данные:
Хостер - truevds.ru, XEN виртуализация.
Дистрибутив - Ubuntu 9.04 Server (нужен именно он)
Ядро - 2.6.26-2-xen-686
Внешнее проявление:
При запросе php-скрипта, в браузере показывается ошибка:
502 Bad Gateway
В логе появляется строка:
[error] 9599#0: *12 recv() failed (104: Connection reset by peer)
while reading response header from upstream,
client: 109.165.44.169,
server: webhamster.ru,
request: "GET /phpinfo.php HTTP/1.1",
upstream: "fastcgi://127.0.0.1:8888",
host: "webhamster.ru"
Последовательность моих действий по настройке:
1. Установил php-cgi командой
apt-get install php-cgi
2. Сделал скрипт start_php_fcgi.sh для запуска PHP в режиме FastCGI сервера:
#!/bin/bash## ABSOLUTE path to the PHP binary
PHPFCGI="/usr/bin/php-cgi"
## tcp-port to bind on
FCGIPORT="8888"
## IP to bind on
FCGIADDR="127.0.0.1"
## number of PHP children to spawn
PHP_FCGI_CHILDREN=5
## number of request before php-process will be restarted
PHP_FCGI_MAX_REQUESTS=1000
# allowed environment variables sperated by spaces
ALLOWED_ENV="ORACLE_HOME PATH USER"
## if this script is run as root switch to the following user
USERID=www-data
################## no config below this line
if test x$PHP_FCGI_CHILDREN = x; then
PHP_FCGI_CHILDREN=5
fi
ALLOWED_ENV="$ALLOWED_ENV PHP_FCGI_CHILDREN"
ALLOWED_ENV="$ALLOWED_ENV PHP_FCGI_MAX_REQUESTS"
ALLOWED_ENV="$ALLOWED_ENV FCGI_WEB_SERVER_ADDRS"
if test x$UID = x0; then
EX="/bin/su -m -c \"$PHPFCGI -q -b $FCGIADDR:$FCGIPORT\" $USERID"
else
EX="$PHPFCGI -b $FCGIADDR:$FCGIPORT"
fi
echo $EX
# copy the allowed environment variables
E=
for i in $ALLOWED_ENV; do
E="$E $i=${!i}"
done
# clean environment and set up a new one
nohup env - $E sh -c "$EX" &> /dev/null &
3. Запускаю этот скрипт (start_php_fcgi.sh)
4. Проверяю, работает ли PHP как сервер. Да, работает:
# ps aux | grep php
root 9665 pts/1 S sh -c /bin/su -m -c "/usr/bin/php-cgi -q -b 127.0.0.1:8888" www-data
www-data 9666 pts/1 S /bin/su -m -c /usr/bin/php-cgi -q -b 127.0.0.1:8888 www-data
www-data 9667 pts/1 S sh -c /usr/bin/php-cgi -q -b 127.0.0.1:8888
www-data 9668 ? Ss /usr/bin/php-cgi -q -b 127.0.0.1:8888
www-data 9669 ? S /usr/bin/php-cgi -q -b 127.0.0.1:8888
www-data 9670 ? S /usr/bin/php-cgi -q -b 127.0.0.1:8888
www-data 9671 ? S /usr/bin/php-cgi -q -b 127.0.0.1:8888
www-data 9672 ? S /usr/bin/php-cgi -q -b 127.0.0.1:8888
www-data 9673 ? S /usr/bin/php-cgi -q -b 127.0.0.1:8888
root 9727 pts/1 S+ grep php
5. Проверяю, слушает ли PHP действительно 8888 порт. Да, слушает:
# netstat -lnp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 9598/nginx
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1417/sshd
tcp 0 0 127.0.0.1:8888 0.0.0.0:* LISTEN 9668/php-cgi
tcp6 0 0 :::22 :::* LISTEN 1417/sshd
udp 0 0 594.527.568.513:123 0.0.0.0:* 1332/ntpd
udp 0 0 127.0.0.1:123 0.0.0.0:* 1332/ntpd
udp 0 0 0.0.0.0:123 0.0.0.0:* 1332/ntpd
udp6 0 0 fe80::216:3eff:fe1b:123 :::* 1332/ntpd
udp6 0 0 ::1:123 :::* 1332/ntpd
udp6 0 0 :::123 :::* 1332/ntpd
Active UNIX domain sockets (only servers)
Proto RefCnt Flags Type State I-Node PID/Program name Path
6. Прописываю в следущую конфигурацию Nginx:
server {
listen 80;
server_name webhamster.ru; error_log /var/log/nginx/webhamster.warn.log warn;
access_log /var/log/nginx/webhamster.access.log;
root /var/www/webhamster;
charset utf-8;
location / {
root /var/www/webhamster;
index index.html index.htm;
}
location ~ \.php$ {
fastcgi_pass 127.0.0.1:8888;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;
include fastcgi_params;
}
}
7. Перезапускаю Nginx:
# /etc/init.d/nginx restart
Restarting nginx: nginx.
8. Создаю в каталоге /var/www/webhamster два файла: hello.html и phpinfo.php.
В hello.html прописываю "Hello" - и при открытии URL "webhamster.ru/hello.html" я вижу эту надпись.
В phpinfo.php прописываю "<?php phpinfo(); ?>" - и при открытии URL "webhamster.ru/phpinfo.php" получаю ошибку "502 Bad Gateway". Установил права на этот файл 777, ошибка осталась.
Вопрос: что еще где нужно крутануть, чтобы Nginx начал нормально коннектиться к серверу PHP Fast CGI? Что где проверить? Как узнать - это Nginx цепляется "не туда", или всетаки Nginx цепляется туда, но PHP не хочет отвечать Nginx?