Как установить блоки сервера Nginx в Ubuntu 22.04

5 mar 2024 3 min di lettura
Как установить блоки сервера Nginx в Ubuntu 22.04
Indice dei contenuti

Введение

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. Вы можете повторить описанные выше шаги и создать дополнительные блоки серверов для всех ваших доменов.

Если у вас возникнут какие-либо проблемы, не стесняйтесь оставлять комментарии.

Support us with a

Successivamente, completa il checkout per l'accesso completo a Noviello.it.
Bentornato! Accesso eseguito correttamente.
Ti sei abbonato con successo a Noviello.it.
Successo! Il tuo account è completamente attivato, ora hai accesso a tutti i contenuti.
Operazione riuscita. Le tue informazioni di fatturazione sono state aggiornate.
La tua fatturazione non è stata aggiornata.