Серверные блоки Nginx позволяют запускать более одного веб-сайта на одном компьютере. С помощью серверных блоков вы можете указать корень документа сайта (каталог, содержащий файлы сайта), создать отдельную политику безопасности для каждого сайта, использовать разные SSL-сертификаты для каждого сайта и многое другое.
В этом руководстве мы покажем вам, как настроить серверные блоки Nginx в Debian 9.
Содержание
Подготовка
Прежде чем продолжить изучение этого руководства, убедитесь, что вы выполнили следующие предварительные требования:
- Доменное имя, указывающее на IP вашего публичного сервера. Мы будем использовать
example.com
. - Установлен Nginx .
- Вы вошли в систему как root или пользователь с привилегиями sudo .
Server Blocks
называются Virtual host
. Виртуальный хост — это термин Apache.Создайте структуру каталогов
Корневой каталог документа — это каталог, в котором файлы веб-сайта для доменного имени хранятся и обслуживаются в ответ на запросы. Корнем документа может быть любой каталог на вашем сервере Debian.
Мы будем использовать следующую структуру каталогов:
/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;
}
}
Вы можете назвать файл конфигурации по своему усмотрению, но обычно лучше использовать доменное имя.
Включите новый файл блока сервера, создав символическую ссылку из файла в каталог с 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. Вы можете повторить описанные выше шаги и создать дополнительные серверные блоки для всех ваших доменов.
Если вы столкнулись с какой-либо проблемой, не стесняйтесь оставлять комментарий.
Этот пост является частью серии «Как установить LEMP Stack в Debian 9». Другие сообщения из этой серии: