Как настроить блоки сервера Nginx в Debian 10

Linux

Блок сервера — это директива Nginx, определяющая настройки для конкретного домена, позволяющая запускать несколько сайтов на одном сервере.

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

Давайте разберемся вместе, как настроить блоки сервера Nginx в Debian 10.

Предварительный условия

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

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

В некоторых документах термин Блоки сервера называется virtual host. Virtual host — это термин Apache.

Структура каталогов

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

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

/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 в корневом каталоге документа домена:

sudo nano /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>

Чтобы избежать проблем с разрешениями, измените право собственности на корневую директорию документа домена на пользователя Nginx (www-data):

sudo chown -R www-data: /var/www/example.com

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

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

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

sudo nano /etc/nginx/sites-available/example.com.conf
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;
    }
}

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

Включите новый файл блока сервера, создав символическую ссылку из файла на каталог с включенными сайтами:

sudo ln -s /etc/nginx/sites-available/example.com.conf /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 в Debian 10

Заключение

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

Если вы хотите обезопасить свой сайт с помощью SSL-сертификата, вы можете сгенерировать и установить бесплатный SSL-сертификат Letsencrypt.

Как создать SSL-сертификат Letsencrypt в Debian 10 мы рассмотрим в следующей статье.

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

Oleg Kozlov

QA Engineer, web-testing, Adobe illustration, Adobe Photoshop, Motion Design, Music, Games, Mac OS.

Оцените автора
Техносфера
Добавить комментарий