И так выложу инструкцию для того, чтобы получить то, что было нужно именно мне.
И так 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
Теперь всё должно работать как надо.
Если Вы нашли в статье какие-то ошибки или бессмысленные или бестолковые действия, убедительная просьба об этом отписать.
Комментариев нет:
Отправить комментарий