Сейчас 127 заметки.
Установка и настройка веб-сервера LEMP на Debian 5 (Lenny): различия между версиями
Admin (обсуждение | вклад) |
Admin (обсуждение | вклад) |
||
(не показаны 2 промежуточные версии этого же участника) | |||
Строка 4: | Строка 4: | ||
Это руководство предполагает, что вы вошли в систему как суперпользователь root. | Это руководство предполагает, что вы вошли в систему как суперпользователь root. | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
Перед началом установки необходимо обновить репозитории и установленные программы: | Перед началом установки необходимо обновить репозитории и установленные программы: | ||
− | apt-get update | + | <pre>apt-get update |
− | apt-get upgrade | + | apt-get upgrade</pre> |
− | Установка веб-сервера Nginx | + | |
+ | |||
+ | '''Установка веб-сервера Nginx''' | ||
Есть несколько жизнеспособных и популярных способов для установки стека LEMP: | Есть несколько жизнеспособных и популярных способов для установки стека LEMP: | ||
− | + | Первый вариант устанавливает пакеты с программным обеспечением из репозитория Debian содержащего стабильные версии веб-сервера и дополнительного программного обеспечения. | |
− | + | При втором случае, пакеты устанавливаются из репозитория проекта Debian Backports. Backports пакеты более актуальны, чем их стабильные аналоги, предоставляемые стандартным репозиторием Debian. | |
− | + | Последний вариант требует загрузки исходных кодов Nginx и компиляции программного обеспечения вручную. Данный способ установки позволяет запускать самые последние версии программного обеспечения. | |
Все варианты совместимы, но в большинстве случаев мы рекомендуем использовать пакеты из проекта Debian или Backports если ваши потребности требуют версия новее, чем предоставленная в репозитории Debian. | Все варианты совместимы, но в большинстве случаев мы рекомендуем использовать пакеты из проекта Debian или Backports если ваши потребности требуют версия новее, чем предоставленная в репозитории Debian. | ||
− | Одна из причин по которой Вам необходимо воспользоваться вариантом сборки из исходников - установка дополнительных модулей во время компиляции и получение функций, добавленных в более поздних версиях | + | Одна из причин по которой Вам необходимо воспользоваться вариантом сборки из исходников - установка дополнительных модулей во время компиляции и получение функций, добавленных в более поздних версиях |
− | Установка Nginx из пакета Debian | + | |
+ | |||
+ | '''Установка Nginx из пакета Debian''' | ||
Если Вы выбрали первый вариант установки - из репозитория Debian, Вам необходимо ввести в консоль следующую команду: | Если Вы выбрали первый вариант установки - из репозитория Debian, Вам необходимо ввести в консоль следующую команду: | ||
− | apt-get install nginx | + | <pre>apt-get install nginx</pre> |
Результатом выполнения команды будет установленный веб-сервер Nginx последней стабильной версии. | Результатом выполнения команды будет установленный веб-сервер Nginx последней стабильной версии. | ||
Строка 43: | Строка 37: | ||
Редактируем файл: /etc/apt/sources.list | Редактируем файл: /etc/apt/sources.list | ||
− | deb http://backports.debian.org/debian-backports lenny-backports main | + | <pre>deb http://backports.debian.org/debian-backports lenny-backports main</pre> |
После этого необходимо отредактировать файл /etc/apt/preferences, добавив в него строки: | После этого необходимо отредактировать файл /etc/apt/preferences, добавив в него строки: | ||
Строка 49: | Строка 43: | ||
Редактируем файл: /etc/apt/preferences | Редактируем файл: /etc/apt/preferences | ||
− | Package: nginx | + | <pre>Package: nginx |
Pin: release a=lenny-backports | Pin: release a=lenny-backports | ||
− | Pin-Priority: 999 | + | Pin-Priority: 999</pre> |
Теперь необходимо выполнить обновление репозитория и установку Nginx. Для этого выполните следующие команды: | Теперь необходимо выполнить обновление репозитория и установку Nginx. Для этого выполните следующие команды: | ||
− | apt-get update | + | <pre>apt-get update |
− | apt-get install nginx | + | apt-get install nginx</pre> |
Выполните первый запуск Nginx командой: | Выполните первый запуск Nginx командой: | ||
− | /etc/init.d/nginx start | + | <pre>/etc/init.d/nginx start</pre> |
− | Компиляция Nginx из исходных кодов | + | |
+ | |||
+ | '''Компиляция Nginx из исходных кодов''' | ||
Если вы хотите собрать и установить Nginx из исходных кодов, введите следующие команды, чтобы установить необходимые компоненты: | Если вы хотите собрать и установить Nginx из исходных кодов, введите следующие команды, чтобы установить необходимые компоненты: | ||
− | apt-get install libpcre3-dev build-essential libssl-dev sudo | + | <pre>apt-get install libpcre3-dev build-essential libssl-dev sudo</pre> |
Перейдите на страницу загрузки Nginx и скопируйте ссылку на последнюю стабильную (либо необходимую Вам) версию Nginx. Для загрузки Nginx по сети выполните следующие команды: | Перейдите на страницу загрузки Nginx и скопируйте ссылку на последнюю стабильную (либо необходимую Вам) версию Nginx. Для загрузки Nginx по сети выполните следующие команды: | ||
− | cd /opt/ | + | <pre>cd /opt/ |
wget http://nginx.org/download/nginx-0.8.54.tar.gz | wget http://nginx.org/download/nginx-0.8.54.tar.gz | ||
tar -zxvf nginx-0.8.54.tar.gz | tar -zxvf nginx-0.8.54.tar.gz | ||
− | cd /opt/nginx-0.8.54/ | + | cd /opt/nginx-0.8.54/</pre> |
Подготовьте Nginx для компиляции введя команду: | Подготовьте Nginx для компиляции введя команду: | ||
− | ./configure --prefix=/opt/nginx --user=nginx --group=nginx --with-http_ssl_module | + | <pre>./configure --prefix=/opt/nginx --user=nginx --group=nginx --with-http_ssl_module</pre> |
После завершения команды ./configure, Вы увидите информацию о расположении связанных с Nginx файлов. | После завершения команды ./configure, Вы увидите информацию о расположении связанных с Nginx файлов. | ||
− | nginx path prefix: "/opt/nginx" | + | <pre>nginx path prefix: "/opt/nginx" |
nginx binary file: "/opt/nginx/sbin/nginx" | nginx binary file: "/opt/nginx/sbin/nginx" | ||
nginx configuration prefix: "/opt/nginx/conf" | nginx configuration prefix: "/opt/nginx/conf" | ||
Строка 89: | Строка 85: | ||
nginx http client request body temporary files: "client_body_temp" | nginx http client request body temporary files: "client_body_temp" | ||
nginx http proxy temporary files: "proxy_temp" | nginx http proxy temporary files: "proxy_temp" | ||
− | nginx http fastcgi temporary files: "fastcgi_temp" | + | nginx http fastcgi temporary files: "fastcgi_temp"</pre> |
Следующие команды выполнят компиляцию и установку Nginx: | Следующие команды выполнят компиляцию и установку Nginx: | ||
− | make | + | <pre>make |
− | make install | + | make install</pre> |
Создайте в системе пользователя для запуска процессов Nginx. Для этого введите следующую команду: | Создайте в системе пользователя для запуска процессов Nginx. Для этого введите следующую команду: | ||
− | adduser --system --no-create-home --disabled-login --disabled-password --group nginx | + | <pre>adduser --system --no-create-home --disabled-login --disabled-password --group nginx</pre> |
Следующим шагом будет установка и настройка init script который поможет нам запускать и останавливать Nginx. Для этого выполним следующие команды: | Следующим шагом будет установка и настройка init script который поможет нам запускать и останавливать Nginx. Для этого выполним следующие команды: | ||
− | wget http://lib.clodo.ru/public/web-servers/nginx/init-deb.sh | + | <pre>wget http://lib.clodo.ru/public/web-servers/nginx/init-deb.sh |
mv init-deb.sh /etc/init.d/nginx | mv init-deb.sh /etc/init.d/nginx | ||
chmod +x /etc/init.d/nginx | chmod +x /etc/init.d/nginx | ||
− | /usr/sbin/update-rc.d -f nginx defaults | + | /usr/sbin/update-rc.d -f nginx defaults</pre> |
Для первого запуска Nginx выполните команду: | Для первого запуска Nginx выполните команду: | ||
− | /etc/init.d/nginx start | + | <pre>/etc/init.d/nginx start</pre> |
− | Настройка виртуальных хостов на Nginx | + | |
+ | |||
+ | '''Настройка виртуальных хостов на Nginx''' | ||
Независимо от используемого метода установки Nginx, вам нужно настроить веб-сервер указав виртуальные хосты. Рассмотрим пример конфигурации виртуального хоста Nginx: | Независимо от используемого метода установки Nginx, вам нужно настроить веб-сервер указав виртуальные хосты. Рассмотрим пример конфигурации виртуального хоста Nginx: | ||
− | server { | + | <pre>server { |
listen 80; | listen 80; | ||
server_name www.clodo.com clodo.com; | server_name www.clodo.com clodo.com; | ||
Строка 124: | Строка 122: | ||
index index.html index.htm; | index index.html index.htm; | ||
} | } | ||
− | } | + | }</pre> |
Необходимо создать указанные в конфигурации каталоги. Для этого выполним следующие команды: | Необходимо создать указанные в конфигурации каталоги. Для этого выполним следующие команды: | ||
− | mkdir -p /srv/www/clodo.com/public_html | + | <pre>mkdir -p /srv/www/clodo.com/public_html |
− | mkdir -p /srv/www/clodo.com/logs | + | mkdir -p /srv/www/clodo.com/logs</pre> |
Если для установки Nginx вы использовали пакеты из репозитория Debian, создайте конфигурационный файл /etc/nginx/sites-available/clodo.com содержащий указанную выше конфигурацию Nginx, а затем введите следующую команду для активации новой конфигурации и перезапуска веб-сервера: | Если для установки Nginx вы использовали пакеты из репозитория Debian, создайте конфигурационный файл /etc/nginx/sites-available/clodo.com содержащий указанную выше конфигурацию Nginx, а затем введите следующую команду для активации новой конфигурации и перезапуска веб-сервера: | ||
− | ln -s /etc/nginx/sites-available/clodo.com /etc/nginx/sites-enabled | + | <pre>ln -s /etc/nginx/sites-available/clodo.com /etc/nginx/sites-enabled |
− | /etc/init.d/nginx restart | + | /etc/init.d/nginx restart</pre> |
Для того что бы отключить конфигурацию, выполните команды: | Для того что бы отключить конфигурацию, выполните команды: | ||
− | rm /etc/nginx/sites-enabled/clodo.com | + | <pre>rm /etc/nginx/sites-enabled/clodo.com |
− | /etc/init.d/nginx restart | + | /etc/init.d/nginx restart</pre> |
При деактивации конфигурации, конфигурационный файл сохраняется и Вы можете в любой момент снова активировать необходимую конфигурацию веб-сервера. | При деактивации конфигурации, конфигурационный файл сохраняется и Вы можете в любой момент снова активировать необходимую конфигурацию веб-сервера. | ||
Строка 147: | Строка 145: | ||
Редактируем файл: /nginx/conf/nginx.conf | Редактируем файл: /nginx/conf/nginx.conf | ||
− | http { | + | <pre>http { |
# [...] | # [...] | ||
Строка 153: | Строка 151: | ||
# [...] | # [...] | ||
− | } | + | }</pre> |
Сделанное изменение включает расположение директории sites-enabled. | Сделанное изменение включает расположение директории sites-enabled. | ||
Строка 161: | Строка 159: | ||
Редактируем файл: /opt/nginx/conf/nginx.conf | Редактируем файл: /opt/nginx/conf/nginx.conf | ||
− | http { | + | <pre>http { |
# [...] | # [...] | ||
Строка 167: | Строка 165: | ||
# [...] | # [...] | ||
− | } | + | }</pre> |
После этого необходимо создать файл конфигурации виртуального хоста по примеру указанному выше (clodo.com) | После этого необходимо создать файл конфигурации виртуального хоста по примеру указанному выше (clodo.com) | ||
Строка 173: | Строка 171: | ||
После того как вы настроили конфигурационные файлы Nginx, перезапустите веб-сервер для активации новой конфигурации, выполнив следующую команду: | После того как вы настроили конфигурационные файлы Nginx, перезапустите веб-сервер для активации новой конфигурации, выполнив следующую команду: | ||
− | /etc/init.d/nginx restart | + | <pre>/etc/init.d/nginx restart</pre> |
Перед перезапуском убедитесь, что каталоги на которые ведут ссылки в вашей конфигурации существуют. | Перед перезапуском убедитесь, что каталоги на которые ведут ссылки в вашей конфигурации существуют. | ||
− | Установка и настройка PHP с FastCGI | + | |
+ | ''' | ||
+ | Установка и настройка PHP с FastCGI''' | ||
Для развертывания приложений PHP, вам установить связку PHP-FastCGI, позволяющее Nginx правильно обрабатывать и обслуживать страницы, содержащие PHP код. Для начала процесса установки, необходимо выполнить команду: | Для развертывания приложений PHP, вам установить связку PHP-FastCGI, позволяющее Nginx правильно обрабатывать и обслуживать страницы, содержащие PHP код. Для начала процесса установки, необходимо выполнить команду: | ||
− | apt-get install php5-cli php5-cgi build-essential wget psmisc | + | <pre>apt-get install php5-cli php5-cgi build-essential wget psmisc</pre> |
Посетите сайт проекта spawn-fcgi и найдите ссылку для скачивания последней версии FastCGI. После этого выполните следующие команды: | Посетите сайт проекта spawn-fcgi и найдите ссылку для скачивания последней версии FastCGI. После этого выполните следующие команды: | ||
− | cd /opt | + | <pre>cd /opt |
wget http://www.lighttpd.net/download/spawn-fcgi-1.6.3.tar.gz | wget http://www.lighttpd.net/download/spawn-fcgi-1.6.3.tar.gz | ||
tar -zxvf spawn-fcgi-1.6.3.tar.gz | tar -zxvf spawn-fcgi-1.6.3.tar.gz | ||
Строка 191: | Строка 191: | ||
make | make | ||
make install | make install | ||
− | ln -s /opt/spawn-fcgi/bin/spawn-fcgi /usr/bin/spawn-fcgi | + | ln -s /opt/spawn-fcgi/bin/spawn-fcgi /usr/bin/spawn-fcgi</pre> |
Выполните следующую последовательность команд для загрузки скрипта оболочки для PHP-FastCGI, содержащий сценарий для контроля процесса первого старта: | Выполните следующую последовательность команд для загрузки скрипта оболочки для PHP-FastCGI, содержащий сценарий для контроля процесса первого старта: | ||
− | cd /opt/ | + | <pre>cd /opt/ |
wget https://library.linode.com/lemp-guides/reference/php-fastcgi-deb | wget https://library.linode.com/lemp-guides/reference/php-fastcgi-deb | ||
mv /opt/php-fastcgi-deb /usr/bin/php-fastcgi | mv /opt/php-fastcgi-deb /usr/bin/php-fastcgi | ||
Строка 203: | Строка 203: | ||
chmod +x /etc/init.d/php-fastcgi | chmod +x /etc/init.d/php-fastcgi | ||
/etc/init.d/php-fastcgi start | /etc/init.d/php-fastcgi start | ||
− | update-rc.d php-fastcgi defaults | + | update-rc.d php-fastcgi defaults</pre> |
Необходимо изменить файл конфигурации виртуального хоста Nginx по примеру указанному ниже: | Необходимо изменить файл конфигурации виртуального хоста Nginx по примеру указанному ниже: | ||
− | server { | + | <pre>server { |
listen 80; | listen 80; | ||
server_name www.clodo.com clodo.com; | server_name www.clodo.com clodo.com; | ||
Строка 224: | Строка 224: | ||
fastcgi_param SCRIPT_FILENAME /srv/www/clodo.com/public_html$fastcgi_script_name; | fastcgi_param SCRIPT_FILENAME /srv/www/clodo.com/public_html$fastcgi_script_name; | ||
} | } | ||
− | } | + | }</pre> |
Такая конфигурация гарантирует, что все ресурсы, имеющие расширение .php, будут обработаны с помощью FastCGI. Когда вы завершили изменения в конфигурации, убедитесь, что виртуальный хост включен и выполните следующую команду, чтобы перезапустить веб-сервер: | Такая конфигурация гарантирует, что все ресурсы, имеющие расширение .php, будут обработаны с помощью FastCGI. Когда вы завершили изменения в конфигурации, убедитесь, что виртуальный хост включен и выполните следующую команду, чтобы перезапустить веб-сервер: | ||
− | /etc/init.d/nginx restart | + | <pre>/etc/init.d/nginx restart</pre> |
Теперь на нашем веб-сервере работают php-скрипты. | Теперь на нашем веб-сервере работают php-скрипты. | ||
− | Установка и настройка сервера баз данных MySQL | + | |
+ | |||
+ | '''Установка и настройка сервера баз данных MySQL''' | ||
MySQL - система управления базами данных (СУБД) очень популярная в веб-разработке. MySQL используется для хранения данных для многих популярных веб-приложений. | MySQL - система управления базами данных (СУБД) очень популярная в веб-разработке. MySQL используется для хранения данных для многих популярных веб-приложений. | ||
− | Установка MySQL | + | |
+ | |||
+ | '''Установка MySQL''' | ||
Первым шагом является установка MySQL-сервера с поддержкой PHP, для этого необходимо выполнить следующую команду: | Первым шагом является установка MySQL-сервера с поддержкой PHP, для этого необходимо выполнить следующую команду: | ||
− | apt-get install mysql-server php5-mysql | + | <pre>apt-get install mysql-server php5-mysql</pre> |
Во время установки вам будет предложено ввести пароль. Введенный пароль вы сможете изменить позже. | Во время установки вам будет предложено ввести пароль. Введенный пароль вы сможете изменить позже. | ||
Строка 247: | Строка 251: | ||
После установки MySQL, рекомендуется использовать mysql_secure_installation, эта программа поможет вам настроить безопасность в MySQL. Во время работы mysql_secure_installation, вам будет представлена возможность изменить пароль MySQL для root пользователя (по умолчанию он не установлен), удалить анонимные учетные записи пользователей и удалить тестовые базы данных. На все предложения запущенной программы рекомендуется, чтобы вы ответили "да" на все предложенные параметры. Если вам будет предложено перезагрузить таблицы привилегий, выберите "да". Выполните следующую команду, чтобы запустить программу: | После установки MySQL, рекомендуется использовать mysql_secure_installation, эта программа поможет вам настроить безопасность в MySQL. Во время работы mysql_secure_installation, вам будет представлена возможность изменить пароль MySQL для root пользователя (по умолчанию он не установлен), удалить анонимные учетные записи пользователей и удалить тестовые базы данных. На все предложения запущенной программы рекомендуется, чтобы вы ответили "да" на все предложенные параметры. Если вам будет предложено перезагрузить таблицы привилегий, выберите "да". Выполните следующую команду, чтобы запустить программу: | ||
− | mysql_secure_installation | + | <pre>mysql_secure_installation</pre> |
Далее, мы создадим базу данных и предоставим пользователям разрешений на использование баз данных. Для этого необходимо войти в MySQL: | Далее, мы создадим базу данных и предоставим пользователям разрешений на использование баз данных. Для этого необходимо войти в MySQL: | ||
− | mysql -u root -p | + | <pre>mysql -u root -p</pre> |
После того как вы введете пароль root пользователя MySQL, вы сможете начать взаимодействие с MySQL сервером. | После того как вы введете пароль root пользователя MySQL, вы сможете начать взаимодействие с MySQL сервером. | ||
Строка 257: | Строка 261: | ||
Для создания базы данных и предоставления пользователям привилегий, введите следующую команду. Обратите внимание, двоеточие (;) в конце линии означает завершение вводы команды. Команда должна выглядеть следующим образом: | Для создания базы данных и предоставления пользователям привилегий, введите следующую команду. Обратите внимание, двоеточие (;) в конце линии означает завершение вводы команды. Команда должна выглядеть следующим образом: | ||
− | create database test; | + | <pre>create database test; |
− | grant all on test.* to ’user’ identified by ’12345’; | + | grant all on test.* to ’user’ identified by ’12345’;</pre> |
В приведенном выше примере, test это имя базы данных, user - имя пользователя c паролем 12345. Обратите внимание, что база данных имен пользователей и паролей используются только подключения к базе данных. Использование этой базы не обязательно. | В приведенном выше примере, test это имя базы данных, user - имя пользователя c паролем 12345. Обратите внимание, что база данных имен пользователей и паролей используются только подключения к базе данных. Использование этой базы не обязательно. | ||
Строка 264: | Строка 268: | ||
Мы завершили настройку MySQL и теперь вы можете передать учетные данные базы данных пользователям. Для выхода из администрирования MySQL введите следующую команду: | Мы завершили настройку MySQL и теперь вы можете передать учетные данные базы данных пользователям. Для выхода из администрирования MySQL введите следующую команду: | ||
− | quit | + | <pre>quit</pre> |
Для того, чтобы PHP смогут получить доступ к MySQL, необходимо перезапустить PHP следующей командой: | Для того, чтобы PHP смогут получить доступ к MySQL, необходимо перезапустить PHP следующей командой: | ||
− | /etc/init.d/php-fastcgi restart | + | <pre>/etc/init.d/php-fastcgi restart</pre> |
Поздравляем! Вы создали веб-сервер Nginx+PHP+FastCGI+MySQL! | Поздравляем! Вы создали веб-сервер Nginx+PHP+FastCGI+MySQL! |
Текущая версия на 18:13, 15 апреля 2012
Это руководство предоставляет пошаговую инструкцию по установке полнофункционального стека 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!