пятница, 18 декабря 2009 г.

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

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

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



И так 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


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

Комментариев нет:

Отправить комментарий