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

Блок сервера — это директива Nginx, которая определяет настройки для определенного домена, позволяя запускать более одного веб-сайта на одном сервере. Для каждого веб-сайта вы можете установить корень документа сайта (каталог, содержащий файлы веб-сайта), создать отдельную политику безопасности, использовать разные сертификаты SSL и многое другое.

В этой статье описывается, как настроить серверные блоки Nginx в Ubuntu 20.04.

Подготовка

Прежде чем продолжить, убедитесь, что вы выполнили следующие требования:

В некоторых статьях термин «серверные блоки» упоминается как «виртуальный хост». Виртуальный хост — это термин 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 внутри корневого каталога документов домена, который будет отображаться при посещении домена в браузере:

/var/www/example.com/public_html/index.html
<!DOCTYPE html>
<html lang="en" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title>Welcome to example.com</title>
  </head>
  <body>
    <h1>Success! example.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 читает во время запуска.

Откройте текстовый редактор и создайте следующий файл серверного блока:

/etc/nginx/sites-available/example.com
server {
    listen 80;

    server_name example.com www.example.com;

    root /var/www/example.com/public_html;

    index index.html;

    access_log /var/log/nginx/example.com.access.log;
    error_log /var/log/nginx/example.com.error.log;
}
  • server_name : домены, которые должны соответствовать этой конфигурации блока сервера.
  • root : каталог, из которого Nginx будет обслуживать файлы домена.
  • access_log , error_log : указывает расположение файлов журнала.

Конфигурационному файлу можно присвоить любое имя, но обычно лучше использовать доменное имя.

Чтобы включить новый файл блока сервера, создайте символическую ссылку из файла в каталог с поддержкой sites-enabled , который Nginx прочитает во время запуска:

sudo ln -s /etc/nginx/sites-available/example.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://example.com в любом браузере, и вы увидите что-то вроде этого:

Выводы

Мы показали вам, как создавать серверные блоки Nginx и размещать несколько доменов на одном сервере Ubuntu. Вы можете повторить описанные выше шаги и создать дополнительные серверные блоки для всех ваших доменов.

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

Оставьте комментарий