LEMP
— набор программного обеспечения для работы сайтов и веб-приложений. В отличие от LAMP (Linux, Apache, MySQL/MariaDB, PHP), в LEMP в качестве веб-сервера используется не Apache, а Nginx (читается как Engine-X):
- Linux — операционная система;
- Engine-X — веб-сервер nginx;
- MySQL / MariaDB — сервер баз данных;
- PHP — интерпретатор применяемого в разработке web-приложений языка PHP
Установка веб-сервера Nginx
Nginx позволяет обеспечить стабильно высокую производительность сайтов даже при очень высоких нагрузках. Он популярен для обеспечения работы высоконагруженных веб-сервисов — используется Yandex, Mail.ru, VKontakte, Habr и др.
Важно помнить, что многие популярные CMS (например, WordPress) заточены под работу с Apache, поэтому некоторые их функции не будут работать под Nginx-ом без специфических настроек.
Установка выполняется в один шаг:
Ubuntu и Debian:
apt update && apt -y install nginx
CentOS:
yum -y install nginx
После установки проверим, что веб-сервер запустился.
systemctl status nginx

На Ubuntu и Debian службы после установки запускаются и добавляются в автозапуск автоматически, на Centos это нужно сделать вручную. Запустить веб-сервер и настроить его автоматический старт после загрузки системы можно следующим образом:
systemctl start nginx && systemctl enable nginx
Дополнительно можно настроить веб-сервер на автоматический перезапуск в случае аварийного отключения службы. Для этого добавим отдельную директорию и создадим в ней наш новый конфигурационный файл:
mkdir -p /etc/systemd/system/nginx.service.d/ touch /etc/systemd/system/nginx.service.d/restart.conf
Откроем файл в любом консольном текстовом редакторе:
nano /etc/systemd/system/nginx.service.d/restart.conf
И добавим туда следующие строки:
[Service] Restart=always RestartSec=5s
Сохраним файл и перезагрузим менеджер служб:
systemctl daemon-reload
На CentOS после установки нужно отредактировать настройки встроенного фаервола:
firewall-cmd --permanent --zone=public --add-service=http --add-service=https firewall-cmd --reload
Проверить, что настройки успешно применились, можно с помощью команды:
firewall-cmd --list-all
В блоке Services
в списке должны отображаться http
и https
.

Чтобы проверить, что веб-сервер заработал и может обрабатывать запросы к серверу, введите IP-адрес вашего сервера в адресной строке браузера. Откроется приветственная страница Nginx:
Для Debian и Ubuntu:

Для CentOS:

Установка сервера баз данных
MariaDB — сервер баз данных с открытым исходным кодом. Процесс установки состоит из двух шагов: установки и запуска автонастройки безопасности.
Установка:
Ubuntu и Debian:
apt -y install mariadb-server mariadb-client
CentOS:
yum -y install mariadb mariadb-server
Чтобы проверить, что сервер баз данных запустился и работает без ошибок, выполните команду:
systemctl status mariadb
Если сервис не запустился автоматически (статус dead
), активируйте и добавьте службу в автозагрузку вручную:
systemctl start mariadb && systemctl enable mariadb
После установки можно проверить версию установленного сервера баз данных:
Ubuntu и Debian:
mariadb --version
CentOS:
mysql --version

Для редактирования параметров безопасности запустите встроенный инструмент настройки:
mysql_secure_installation
C его помощью вы сможете отключить небезопасные опции, которые по умолчанию включены для работы тестового режима после установки.
На первом шаге скрипт предложит ввести текущий пароль root
от сервера баз данных. По умолчанию после установки он не задан, достаточно нажать Enter. После этого будет предложено подтвердить или отклонить дополнительные настройки безопасности — для согласия введите y (yes), для отказа — любую другую клавишу и нажмите Enter. Рекомендуется подтвердить все параметры, так как они воплощают базовые рекомендации по безопасности сервера БД.
- Новый пароль
root
для сервера баз данных (по умолчанию отсутствует) — потребуется ввести и подтвердить новый пароль; - Удаление анонимных пользователей (один присутствует по умолчанию для тестового режима);
- Отключение удалённого доступа для пользователя root;
- Удаление тестовой базы данных и доступов к ней;
- Перезагрузка таблиц для применения новых параметров.

Установка PHP и дополнительных расширений
Проверить доступную для установки версию PHP можно командой:
Ubuntu и Debian:
apt show php
CentOS:
yum info php
Знать её нужно для корректной установки нужных компонентов на следующем шаге (для Ubuntu и Debian). В примере версия PHP — 7.4. Вам при установке нужно заменить её в команде на ту, которая доступна для вашей операционной системы.

Если версия вам подходит, после этого можно перейти к установке:
Ubuntu и Debian:
apt -y install php7.4 php7.4-fpm php7.4-mysql php-common php7.4-cli php7.4-common php7.4-json php7.4-opcache php7.4-readline php7.4-mbstring php7.4-xml php7.4-gd php7.4-curl php7.4-zip
CentOS:
yum -y install php-fpm php-mysqlnd php-cli php-json php-mbstring php-xml php-gd php-curl php-zip
Дополнительные расширения PHP, доступные для установки, можно посмотреть командой:
- Ubuntu и Debian:Для конкретной версии:
apt-cache search php | egrep '7.4' | grep module
Версии по умолчанию:
apt-cache search php | egrep 'module' | grep default
CentOS:
yum search php | grep module

Установить выбранный модуль можно командой:
Ubuntu и Debian:
apt -y install php7.4-soap
CentOS:
yum -y install php-soap
После установки PHP запускаем менеджер процессов php-fpm
и добавляем его в автозагрузку:
Ubuntu и Debian:
systemctl start php7.4-fpm && systemctl enable php7.4-fpm
CentOS:
systemctl start php-fpm && systemctl enable php-fpm
Проверим установленную версию PHP:
php -v

После установки PHP нужно отредактировать настройки php-fpm
по умолчанию, предназначенные для веб-сервера Apache:
Ubuntu и Debian:
nano /etc/php/7.4/fpm/pool.d/www.conf
CentOS:
vim /etc/php-fpm.d/www.conf
В файле ищем блок кода Unix user/group of processes
и меняем apache
на www-data
для Debian и Ubuntu и nginx
для CentOS.

Остался последний штрих. Открываем для редактирования конфигурационный файл PHP:
Ubuntu и Debian:
nano /etc/php/7.4/fpm/php.ini
CentOS:
vim /etc/php.ini
В файле ищем раздел Paths and Directories
(он почти в самом конце файла), внутри находим параметр cgi.fix_pathinfo
. Нужно раскомментировать его (удалить «;»
в начале строки) и изменить значение с «1»
на «0»
.

После этого сохраняем файл и перезапускаем веб-сервер, чтобы новые настройки применились:
Ubuntu и Debian:
systemctl reload nginx && systemctl reload php7.4-fpm
CentOS:
systemctl reload nginx && systemctl reload php-fpm
Настройка базового конфигурационного файла для сайта
Чтобы веб-сервер мог корректно обрабатывать запросы к сайтам, осталось добавить базовый конфигурационный файл вместо установленного по умолчанию. Для этого:
Удаляем конфигурационный файл default
, использующийся по умолчанию, и создаём его замену, default.conf
:
Ubuntu и Debian:
unlink /etc/nginx/sites-enabled/default touch /etc/nginx/sites-available/default.conf ln /etc/nginx/sites-available/default.conf /etc/nginx/sites-enabled/default.conf
CentOS:
touch /etc/nginx/conf.d/default.conf
Откроем новый файл в консольном текстовом редакторе и добавим туда содержимое:
Ubuntu и Debian:
nano /etc/nginx/sites-available/default.conf
CentOS:
vim /etc/nginx/conf.d/default.conf
Скопируйте в файл следующий блок настроек:
Ubuntu и Debian:
server { listen 80; listen [::]:80; server_name _; root /usr/share/nginx/html/; index index.php index.html index.htm index.nginx-debian.html; location / { try_files $uri $uri/ =404; } location ~ \.php$ { fastcgi_pass unix:/run/php/php7.4-fpm.sock; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; include snippets/fastcgi-php.conf; } location ~ /\.ht { access_log off; log_not_found off; deny all; } }
CentOS:
server { listen 80; listen [::]:80; server_name _; root /usr/share/nginx/html/; index index.php index.html index.htm index.nginx-debian.html; location / { try_files $uri $uri/ =404; } location ~ \.php$ { fastcgi_pass unix:/var/run/php-fpm/php-fpm.sock; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } location ~ /\.ht { access_log off; log_not_found off; deny all; } }
Осталось проверить, что в конфигурационном файле отсутствуют ошибки, и перезапустить nginx для применения настроек:
nginx -t

systemctl reload nginx
Проверка параметров PHP через phpinfo()
Чтобы вывести подробный список параметров PHP, можно использовать функцию phpinfo()
. Это может пригодиться в том числе при отладке настроек сайта после размещения на сервере.
Для начала перейдите в корневую директорию вашего сайта. Если сайта ещё нет, по умолчанию это каталог /usr/share/nginx/html
. Создайте файл с именем info.php
и откройте его в любом консольном текстовом редакторе:
touch /usr/share/nginx/html/info.php vim /usr/share/nginx/html/info.php
В файл вставьте следующую конструкцию:
<?php phpinfo(); ?>
Теперь при переходе по ссылке типа http://IP-адрес-сервера/info.php
вы увидите полный список параметров PHP на вашем сервере:

Не забудьте удалить этот файл после проверки. Если оставить его в открытом доступе, информация из него может быть использована злоумышленниками для атак на ваш сайт.
rm /usr/share/nginx/html/info.php
На этом все.