Сейчас 126 заметки.
Установка и настройка веб-сервера LEMP на Debian 5 (Lenny)
Это руководство предоставляет пошаговую инструкцию по установке полнофункционального стека LEMP на Debian 5. Вы получите инструкции по установке Nginx, MySQL и PHP.
Инструкции которые содержатся в этом руководстве протестированы на платформе http://Clodo.ru
Это руководство предполагает, что вы вошли в систему как суперпользователь root.
Перед началом установки необходимо обновить репозитории и установленные программы:
apt-get update apt-get upgrade
Установка веб-сервера Nginx
Есть несколько жизнеспособных и популярных способов для установки стека LEMP:
Первый вариант устанавливает пакеты с программным обеспечением из репозитория Debian содержащего стабильные версии веб-сервера и дополнительного программного обеспечения. При втором случае, пакеты устанавливаются из репозитория проекта Debian Backports. Backports пакеты более актуальны, чем их стабильные аналоги, предоставляемые стандартным репозиторием Debian. Последний вариант требует загрузки исходных кодов Nginx и компиляции программного обеспечения вручную. Данный способ установки позволяет запускать самые последние версии программного обеспечения.
Все варианты совместимы, но в большинстве случаев мы рекомендуем использовать пакеты из проекта Debian или Backports если ваши потребности требуют версия новее, чем предоставленная в репозитории Debian.
Одна из причин по которой Вам необходимо воспользоваться вариантом сборки из исходников - установка дополнительных модулей во время компиляции и получение функций, добавленных в более поздних версиях
Установка Nginx из пакета Debian
Если Вы выбрали первый вариант установки - из репозитория Debian, Вам необходимо ввести в консоль следующую команду:
apt-get install nginx
Результатом выполнения команды будет установленный веб-сервер Nginx последней стабильной версии. Установка Nginx из портированых на Debian пакетов
Между предыдущим вариантом установки и текщим разница незначительна. Необходимо отредактировать файл /etc/apt/sources.list добавив туда следующую строку:
Редактируем файл: /etc/apt/sources.list
deb http://backports.debian.org/debian-backports lenny-backports main
После этого необходимо отредактировать файл /etc/apt/preferences, добавив в него строки:
Редактируем файл: /etc/apt/preferences
Package: nginx Pin: release a=lenny-backports Pin-Priority: 999
Теперь необходимо выполнить обновление репозитория и установку Nginx. Для этого выполните следующие команды:
apt-get update apt-get install nginx
Выполните первый запуск Nginx командой:
/etc/init.d/nginx start
Компиляция Nginx из исходных кодов
Если вы хотите собрать и установить Nginx из исходных кодов, введите следующие команды, чтобы установить необходимые компоненты:
apt-get install libpcre3-dev build-essential libssl-dev sudo
Перейдите на страницу загрузки Nginx и скопируйте ссылку на последнюю стабильную (либо необходимую Вам) версию Nginx. Для загрузки Nginx по сети выполните следующие команды:
cd /opt/ wget http://nginx.org/download/nginx-0.8.54.tar.gz tar -zxvf nginx-0.8.54.tar.gz cd /opt/nginx-0.8.54/
Подготовьте Nginx для компиляции введя команду:
./configure --prefix=/opt/nginx --user=nginx --group=nginx --with-http_ssl_module
После завершения команды ./configure, Вы увидите информацию о расположении связанных с Nginx файлов.
nginx path prefix: "/opt/nginx" nginx binary file: "/opt/nginx/sbin/nginx" nginx configuration prefix: "/opt/nginx/conf" nginx configuration file: "/opt/nginx/conf/nginx.conf" nginx pid file: "/opt/nginx/logs/nginx.pid" nginx error log file: "/opt/nginx/logs/error.log" nginx http access log file: "/opt/nginx/logs/access.log" nginx http client request body temporary files: "client_body_temp" nginx http proxy temporary files: "proxy_temp" nginx http fastcgi temporary files: "fastcgi_temp"
Следующие команды выполнят компиляцию и установку Nginx:
make make install
Создайте в системе пользователя для запуска процессов Nginx. Для этого введите следующую команду:
adduser --system --no-create-home --disabled-login --disabled-password --group nginx
Следующим шагом будет установка и настройка init script который поможет нам запускать и останавливать Nginx. Для этого выполним следующие команды:
wget http://lib.clodo.ru/public/web-servers/nginx/init-deb.sh mv init-deb.sh /etc/init.d/nginx chmod +x /etc/init.d/nginx /usr/sbin/update-rc.d -f nginx defaults
Для первого запуска Nginx выполните команду:
/etc/init.d/nginx start
Настройка виртуальных хостов на Nginx
Независимо от используемого метода установки Nginx, вам нужно настроить веб-сервер указав виртуальные хосты. Рассмотрим пример конфигурации виртуального хоста Nginx:
server { listen 80; server_name www.clodo.com clodo.com; access_log /srv/www/clodo.com/logs/access.log; error_log /srv/www/clodo.com/logs/error.log; location / { root /srv/www/clodo.com/public_html; index index.html index.htm; } }
Необходимо создать указанные в конфигурации каталоги. Для этого выполним следующие команды:
mkdir -p /srv/www/clodo.com/public_html mkdir -p /srv/www/clodo.com/logs
Если для установки Nginx вы использовали пакеты из репозитория Debian, создайте конфигурационный файл /etc/nginx/sites-available/clodo.com содержащий указанную выше конфигурацию Nginx, а затем введите следующую команду для активации новой конфигурации и перезапуска веб-сервера:
ln -s /etc/nginx/sites-available/clodo.com /etc/nginx/sites-enabled /etc/init.d/nginx restart
Для того что бы отключить конфигурацию, выполните команды:
rm /etc/nginx/sites-enabled/clodo.com /etc/init.d/nginx restart
При деактивации конфигурации, конфигурационный файл сохраняется и Вы можете в любой момент снова активировать необходимую конфигурацию веб-сервера.
Если Nginx устанавливался из исходных кодов, есть несколько вариантов настройки. Вы можете добавлять конфигурации виртуальных хостов непосредственно в секцию http файла /opt/nginx/conf/nginx.conf или /etc/nginx/nginx.conf, при этом затрудняется управление виртуальными хостами. Либо, Вы можете перенести управление виртуальными хостами создав различные конфигурационные файлы nginx.conf в предварительно созданных директориях sites-available/ и sites-enabled/.
Редактируем файл: /nginx/conf/nginx.conf
http { # [...] include /opt/etc/nginx/sites-enabled/*; # [...] }
Сделанное изменение включает расположение директории sites-enabled.
В некоторых случаях, имеет смысл создавать и указывать в конфигурации файл с именем /opt/nginx-sites.conf:
Редактируем файл: /opt/nginx/conf/nginx.conf
http { # [...] include /opt/nginx-sites.conf; # [...] }
После этого необходимо создать файл конфигурации виртуального хоста по примеру указанному выше (clodo.com)
После того как вы настроили конфигурационные файлы Nginx, перезапустите веб-сервер для активации новой конфигурации, выполнив следующую команду:
/etc/init.d/nginx restart
Перед перезапуском убедитесь, что каталоги на которые ведут ссылки в вашей конфигурации существуют.
Установка и настройка PHP с FastCGI
Для развертывания приложений PHP, вам установить связку PHP-FastCGI, позволяющее Nginx правильно обрабатывать и обслуживать страницы, содержащие PHP код. Для начала процесса установки, необходимо выполнить команду:
apt-get install php5-cli php5-cgi build-essential wget psmisc
Посетите сайт проекта spawn-fcgi и найдите ссылку для скачивания последней версии FastCGI. После этого выполните следующие команды:
cd /opt wget http://www.lighttpd.net/download/spawn-fcgi-1.6.3.tar.gz tar -zxvf spawn-fcgi-1.6.3.tar.gz cd spawn-fcgi-1.6.3.tar.gz ./configure --prefix=/opt/spawn-fcgi make make install ln -s /opt/spawn-fcgi/bin/spawn-fcgi /usr/bin/spawn-fcgi
Выполните следующую последовательность команд для загрузки скрипта оболочки для PHP-FastCGI, содержащий сценарий для контроля процесса первого старта:
cd /opt/ wget https://library.linode.com/lemp-guides/reference/php-fastcgi-deb mv /opt/php-fastcgi-deb /usr/bin/php-fastcgi chmod +x /usr/bin/php-fastcgi wget https://library.linode.com/lemp-guides/reference/init-php-fastcgi-deb mv /opt/init-php-fastcgi-deb /etc/init.d/php-fastcgi chmod +x /etc/init.d/php-fastcgi /etc/init.d/php-fastcgi start update-rc.d php-fastcgi defaults
Необходимо изменить файл конфигурации виртуального хоста Nginx по примеру указанному ниже:
server { listen 80; server_name www.clodo.com clodo.com; access_log /srv/www/clodo.com/logs/access.log; error_log /srv/www/clodo.com/logs/error.log; location / { root /srv/www/clodo.com/public_html; index index.html index.htm index.php; } location ~ \.php$ { include fastcgi_params; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /srv/www/clodo.com/public_html$fastcgi_script_name; } }
Такая конфигурация гарантирует, что все ресурсы, имеющие расширение .php, будут обработаны с помощью FastCGI. Когда вы завершили изменения в конфигурации, убедитесь, что виртуальный хост включен и выполните следующую команду, чтобы перезапустить веб-сервер:
/etc/init.d/nginx restart
Теперь на нашем веб-сервере работают php-скрипты.
Установка и настройка сервера баз данных MySQL
MySQL - система управления базами данных (СУБД) очень популярная в веб-разработке. MySQL используется для хранения данных для многих популярных веб-приложений.
Установка MySQL
Первым шагом является установка MySQL-сервера с поддержкой PHP, для этого необходимо выполнить следующую команду:
apt-get install mysql-server php5-mysql
Во время установки вам будет предложено ввести пароль. Введенный пароль вы сможете изменить позже.
MySQL сервер готов для настройки и запуска. В данный момент, нет необходимости изменять конфигурационный файл MySQL, можно лишь добавить, что распологается он здесь /etc/my.cnf. Настройка MySQL и настройка базы данных MySQL
После установки MySQL, рекомендуется использовать mysql_secure_installation, эта программа поможет вам настроить безопасность в MySQL. Во время работы mysql_secure_installation, вам будет представлена возможность изменить пароль MySQL для root пользователя (по умолчанию он не установлен), удалить анонимные учетные записи пользователей и удалить тестовые базы данных. На все предложения запущенной программы рекомендуется, чтобы вы ответили "да" на все предложенные параметры. Если вам будет предложено перезагрузить таблицы привилегий, выберите "да". Выполните следующую команду, чтобы запустить программу:
mysql_secure_installation
Далее, мы создадим базу данных и предоставим пользователям разрешений на использование баз данных. Для этого необходимо войти в MySQL:
mysql -u root -p
После того как вы введете пароль root пользователя MySQL, вы сможете начать взаимодействие с MySQL сервером.
Для создания базы данных и предоставления пользователям привилегий, введите следующую команду. Обратите внимание, двоеточие (;) в конце линии означает завершение вводы команды. Команда должна выглядеть следующим образом:
create database test; grant all on test.* to ’user’ identified by ’12345’;
В приведенном выше примере, test это имя базы данных, user - имя пользователя c паролем 12345. Обратите внимание, что база данных имен пользователей и паролей используются только подключения к базе данных. Использование этой базы не обязательно.
Мы завершили настройку MySQL и теперь вы можете передать учетные данные базы данных пользователям. Для выхода из администрирования MySQL введите следующую команду:
quit
Для того, чтобы PHP смогут получить доступ к MySQL, необходимо перезапустить PHP следующей командой:
/etc/init.d/php-fastcgi restart
Поздравляем! Вы создали веб-сервер Nginx+PHP+FastCGI+MySQL!