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

В этой статье рассмотрим пошаговые инструкции о том, как настроить серверные блоки Nginx (аналогично виртуальным хостам Apache) в Ubuntu 18.04.

Предпосылки

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

  • У вас есть доменное имя, указывающее на ваш общедоступный IP-адрес сервера. Мы будем использовать example.com.
  • Вы установили Nginx.
  • Вы вошли в систему как пользователь с привилегиями sudo .

Создайте структуру каталогов

Корень документа — это каталог, в котором файлы веб-сайта для доменного имени хранятся и обслуживаются в ответ на запросы. Вы можете установить корень документа в любое место, которое вы хотите.

Мы будем использовать следующую структуру каталогов:

/var/www/
├── domain1.com
│   └── public_html
├── domain2.com
│   └── public_html
├── domain3.com
│   └── public_html

По сути, мы создадим отдельный каталог для каждого домена, который мы хотим разместить на нашем сервере внутри /var/wwwкаталога. В каждом из этих каталогов мы создадим public_htmlкаталог, в котором будут храниться файлы веб-сайта домена.

Давайте создадим корневой каталог для нашего домена example.com:

sudo mkdir -p /var/www/example.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/example.com

Создать блок сервера

По умолчанию в системах Ubuntu файлы конфигурации серверных блоков Nginx хранятся в /etc/nginx/sites-availableкаталоге, который включается через символические ссылки на /etc/nginx/sites-enabled/каталог.

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


/etc/nginx/сайты-доступны/example.com

server {
    listen 80;
    listen [::]:80;

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

    index index.html;

    server_name example.com www.example.com;

    access_log /var/log/nginx/example.com.access.log;
    error_log /var/log/nginx/example.com.error.log;

    location / {
        try_files $uri $uri/ =404;
    }
}

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

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