Как настроить блоки сервера Nginx на CentOS 8

Настройка блоков сервера Nginx на CentOS 8

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

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

Предпосылки

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

В некоторых документах термин Server Blocks обозначается как « Virtual host . Виртуальный хост — это термин Apache.

Создание структуры каталогов

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

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

 /var/www/ ├── example.com │  └── public_html ├── example2.com │  └── public_html ├── example3.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

  < 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 :

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

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

По умолчанию в CentOS файлы конфигурации блоков сервера Nginx должны заканчиваться на .conf и храниться в каталоге /etc/nginx/conf.d .

Откройте текстовый редактор и создайте файл конфигурации для домена:

 sudo nano /etc/nginx/conf.d/example.com.conf

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

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

/etc/nginx/conf.d/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 ; } }

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

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

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

nginx centos Не используете CentOS 8?
Выберите другую ОС:
центос 7 дебиан 10 дебиан 9 убунту 18.04 убунту 20.04 убунту 22.04

Связанные руководства

Источник

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *