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

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

В этой статье объясняется, как настроить серверные блоки Nginx в Debian 10.

Подготовка

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

В некоторой документации термин « Server Blocks называется 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

Откройте файл и вставьте следующие строки:

/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
/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;
    }
}

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

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

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

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

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

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