Введение
Nginx (произносится как «x-engine») — это высокопроизводительный HTTP-сервер с открытым исходным кодом и обратный прокси-сервер, отвечающий за обработку нагрузки некоторых крупнейших сайтов в Интернете. Его можно использовать в качестве автономного веб-сервера, балансировщика нагрузки, кэша контента и обратного прокси-сервера для HTTP-серверов и серверов, не поддерживающих HTTP.
Блок сервера — это директива Nginx, определяющая настройки для определенного домена, позволяющая запускать более одного веб-сайта на одном сервере. Для каждого веб-сайта вы можете установить корень документа сайта (каталог, содержащий файлы веб-сайта), создать отдельную политику безопасности, использовать разные SSL-сертификаты и многое другое.
В этой статье описывается, как настроить блоки сервера Nginx в Ubuntu 22.04. Вы узнаете, как настроить несколько веб-сайтов на одном сервере и настроить параметры каждого сайта в соответствии со своими потребностями.
Предварительные условия
Прежде чем продолжить, убедитесь, что вы выполнили следующие требования:
- Доменное имя указывает на IP-адрес вашего общедоступного сервера.
- Nginx установлен в вашей системе Ubuntu.
- Вы вошли в систему как пользователь root или пользователь с привилегиями sudo.
Стоит отметить, что в некоторых статьях, посвященных веб-серверам, термин «Серверные блоки» упоминается как «виртуальный хост». Виртуальный хост — это термин Apache.
Создание структуры каталогов
Корень документа — это каталог, в котором файлы веб-сайта для доменного имени хранятся и обслуживаются в ответ на запросы. Вы можете установить корень документа в любое место. В этом примере мы будем использовать следующую структуру каталогов:
/var/www/├── domain1.com
│ └── public_html
├── domain2.com
│ └── public_html
Для каждого домена, размещенного на сервере, корень документа будет установлен в /var/www/<domain_name>/public_html
.
Начните с создания корневого каталога для домена:
sudo mkdir -p /var/www/domain1.com/public_html
Затем создайте файл index.html
и поместите его в корневой каталог вашего домена. Этот файл будет отображаться как страница по умолчанию при доступе к URL-адресу домена в веб-браузере.
<!DOCTYPE html>
<html lang="en" dir="ltr">
<head>
<meta charset="utf-8">
<title>Welcome to domain1.com</title>
</head>
<body>
<h1>Success! domain1.com home page!</h1>
</body>
</html>
Когда вы запускаете команды от имени пользователя sudo, вновь созданные файлы и каталоги будут принадлежать пользователю root. Чтобы избежать проблем с разрешениями, измените владельца корневого каталога документов домена и всех файлов в каталоге на пользователя Nginx ( www-data
):
sudo chown -R www-data: /var/www/domain1.com
Создание серверного блока
В системах Ubuntu файлы конфигурации серверных блоков Nginx хранятся в каталоге /etc/nginx/sites-available
. Их можно включить, создав символические ссылки на каталог /etc/nginx/sites-enabled
, который Nginx читает во время запуска.
Откройте текстовый редактор и создайте следующий файл блока сервера:
server {
listen 80;
server_name domain1.com www.domain1.com;
root /var/www/domain1.com/public_html;
index index.html;
access_log /var/log/nginx/domain1.com.access.log;
error_log /var/log/nginx/domain1.com.error.log;
}
server_name
— домены, которые будут соответствовать этой конфигурации блокировки сервера.root
: каталог, из которого Nginx будет обслуживать файлы домена.access_log
,error_log
: указывает путь к файлам журнала.
Файл конфигурации может иметь любое имя, но обычно лучше использовать доменное имя.
Чтобы включить новый файл блокировки сервера, создайте символическую ссылку из файла на каталог sites-enabled
, который Nginx читает во время запуска:
sudo ln -s /etc/nginx/sites-available/domain1.com /etc/nginx/sites-enabled/
Чтобы убедиться в правильности синтаксиса конфигурации Nginx, запустите тест:
sudo nginx -t
Если ошибок нет, вывод будет выглядеть так:
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
Перезапустите службу Nginx, чтобы изменения вступили в силу:
sudo systemctl restart nginx
Наконец, чтобы убедиться, что блокировка сервера работает должным образом, откройте браузер http://domain1.com
по вашему выбору, и вы увидите что-то вроде этого:
Заключение
Мы показали вам, как создавать серверные блоки Nginx и размещать несколько доменов на одном сервере Ubuntu. Вы можете повторить описанные выше шаги и создать дополнительные блоки серверов для всех ваших доменов.
Если у вас возникнут какие-либо проблемы, не стесняйтесь оставлять комментарии.