Дек 18

PHP в режиме FastCGI в связке с nginx на Debian Linux

Tag: НовостиNIGHT @ 19:18

Сегодня я в очередной раз решил попробовать настроить эту адскую среду. Немного по гуглив нашёл несколько решений но чтобы всё получилось так, как это нужно мне, пришлось их совмещать.

И так выложу инструкцию для того, чтобы получить то, что было нужно именно мне.

И так nginx, php в режиме fastcgi на Debian Linux.

Ставим Debian и во время установки убираем все галочки

[*] Окружение рабочего стола
[*] Базовая система

Все нужные нам компоненты мы позже поставим позже через aptitude.

И так, система установлена, и готова к работе. Логинимся от рута и обновим её.

#aptitude update
#aptitude upgrade

Теперь поставим все необходимые нам пакеты

#aptitude install mc nginx php5 build-essential libpcre3-dev openssl libcurl4-opensssl-dev libbz2-dev

Отлично! Теперь запустим php в режиме fastcgi, для этого нам понадобится стянуть сорцы lighttpd и собрать модуль самим.

И так, подготовим каталог

#mkdir ~/sources
#cd ~/sources

Теперь тяним lighttpd

#wget http://www.lighttpd.net/download/lighttpd-1.4.19.tar.bz2

Распаковываем

#tar jxvf lighttpd-1.4.19.tar.bz2

Теперь идём в каталог с lighttpd.

#cd lighttpd-1.4.19

Конфигурируем и собираем

#./configure -without-zlib
#make

Теперь после того, это собралось скопируем

#cp src/spawn-fcgi /usr/bin/spawn-fcgi

Теперь сорцы можно удалить.

#cd ~/
#rm -Rf sources/

Теперь необходимо всё это дело сделать запускаемым.

#mcedit /usr/bin/php-fastcgi

#!/bin/sh
# Количество процессов
PHP_FCGI_CHILDREN=3
# через сколько обработанных запросов перезапускать экземпляр
PHP_FCGI_MAX_REQUESTS=1000
exec /usr/bin/php5-cgi

Теперь сделаем скрипт автозапуска

#mcedit /etc/init.d/init-fastcgi

#!/bin/bash
PHP_SCRIPT="/usr/bin/spawn-fcgi -a 127.0.0.1 -p 9000 -u www-data -g www-data -f /usr/bin/php-fastcgi"
RETVAL=0
case «$1» in
start)
$PHP_SCRIPT
RETVAL=$?
;;
stop)
killall -9 php5-cgi
RETVAL=$?
;;
restart)
killall -9 php5-cgi
$PHP_SCRIPT
RETVAL=$?
;;
*)
echo "Usage: /etc/init.d/init-fastcgi {start|stop|restart}"
exit 1
;;
esac
exit $RETVAL

Теперь делаем всё это дело запускаемым.

#chmod 755 /usr/bin/php-fastcgi
#chmod 755 /etc/init.d/init-fastcgi

И запускаем

#/etc/init.d/init-fastcgi start

Теперь добавим наш скрипт в автозапуск.

#update-rc.d init-fastcgi defaults

Теперь можно приступать к настройке nginx!

Тут я рассмотрю настройку для localhost, для виртуальных хосотов нужно создать файлы конфигов на подобии того, что я приведу ниже, в директории «/etc/nginx/sites-avalible/» и создать симлинк на этот файл в директории «/etc/nginx/sites-enabled/». Возможно я чуть позже дополню статью созданием виртуальных хостов или напишу отдельную статью, если это нужно.

И так конфиги. Жирным текстом помечено то, что я добавил.

#mcedit /etc/nginx/nginx.conf

user www-data www-data;
worker_processes  1;
error_log  /var/log/nginx/error.log;
pid        /var/run/nginx.pid;
events {
worker_connections  1024;
}
http {
include       /etc/nginx/mime.types;
default_type  application/octet-stream;
access_log      /var/log/nginx/access.log;
sendfile        on;
#tcp_nopush     on;
#keepalive_timeout  0;
keepalive_timeout  65;
tcp_nodelay        on;
gzip  on;
include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
}

Теперь настроим хост

#mcedit /etc/nginx/sites-avalible/default

# You may add here your
# server {
#             …
# }
# statements for each of your virtual hosts

server {
listen   80;
server_name  localhost;
access_log  /var/log/nginx/localhost.access.log;
location / {
root   /www/localhost;
index  index.php index.html index.htm;
}

location /doc {
root   /usr/share;
autoindex on;
allow 127.0.0.1;
deny all;
}

location /images {
root   /usr/share;
autoindex on;
}

#error_page  404  /404.html;
# redirect server error pages to the static page /50x.html
#

error_page   500 502 503 504  /50x.html;
location = /50x.html {
root   /www/localhost;
}

# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
#proxy_pass   http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ \.php$ {
#fastcgi_pass   127.0.0.1:9000;
#fastcgi_index  index.php;
#fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
#includefastcgi_params;
#}

location ~ \.php$ {
root /www/localhost;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /www/localhost$fastcgi_script_name;
include fastcgi_params;
}

# deny access to .htaccess files, if Apache’s document root
# concurs with nginx’s one
#
#location ~ /\.ht {
#deny  all;
#}
}

# another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
#listen   8000;
#listen   somename:8080;
#server_name  somename  alias  another.alias;
#location / {
#root   html;
#index  index.html index.htm;
#}
#}

# HTTPS server
#
#server {
#listen   443;
#server_name  localhost;
#ssl  on;
#ssl_certificate  cert.pem;
#ssl_certificate_key  cert.key;
#ssl_session_timeout  5m;
#ssl_protocols  SSLv2 SSLv3 TLSv1;
#ssl_ciphers  ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
#ssl_prefer_server_ciphers   on;
#location / {
#root   html;
#index  index.html index.htm;
#}
#}

Теперь создадим директорию, где будем хранить наши сайты и разместим там наш тестовый скрипт.

#mkdir -p /www/localhost
#echo "<?php phpinfo(); ?>" > /www/localhost/inxdex.php

И перезапустим nginx

#/etc/init.d/nginx restart

Теперь всё должно работать как надо.

nginx

Если Вы нашли в статье какие-то ошибки или бессмысленные или бестолковые действия, убедительная просьба об этом отписать.