Настройка обратного прокси-сервера с подключением SSL-сертификата на примере Nginx
1. Установка Nginx
sudo apt update && sudo apt install nginx -y
2. Настройка обратного прокси-сервера
Создайте файл конфигурации (например, /etc/nginx/sites-available/example_gitflic
) и добавьте или измените секцию server:
server {
listen 80;
server_name example_gitflic.ru;
location / {
proxy_pass http://127.0.0.1:8080; # Проксируем на внутренний сервер
proxy_send_timeout 3600s;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-Ssl "ON";
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_redirect off;
proxy_buffering off;
proxy_http_version 1.1;
}
}
3. Получение SSL-сертификата
Получение сертификата с помощью утилиты
Для получения SSL-сертификата можно использовать Let’s Encrypt через утилиту Certbot:
sudo apt install certbot python3-certbot-nginx -y
sudo certbot --nginx -d example_gitflic.ru
Подключение самоподписного сертификата
1. Добавлние сертификата
Скопируйте сертификат на сервер, например, в /etc/ssl/certs/
для сертификата и /etc/ssl/private/
для ключа. После этого необходимо добавить строчки в конфигурацию Nginx, описанную в пункте 2.
listen 443 ssl;
ssl_certificate /etc/ssl/certs/example_gitflic.ru.crt;
ssl_certificate_key /etc/ssl/private/example_gitflic.ru.key;
2. Перенаправление HTTP на HTTPS
Чтобы перенаправить HTTP-трафик на HTTPS, при подключении самоподписного сертификата, добавьте следующий блок в конфигурацию Nginx, описанную в пункте 2.:
server {
if ($host = example_gitflic.ru) {
return 301 https://$host$request_uri;
}
listen 80;
server_name example_gitflic.ru;
return 404;
}
4. Создание символический ссылки
Создайте символическую ссылку в директорию sites-enabled
, чтобы активировать конфигурацию:
sudo ln -s /etc/nginx/sites-available/example_gitflic /etc/nginx/sites-enabled/
5. Проверка конфигурации и перезагрузка Nginx
После внесения изменений проверьте конфигурацию:
sudo nginx -t
Если все в порядке, перезапустите Nginx:
sudo nginx -s reload
6. Получение доступа
Приложение будет доступно по адресу https://example_gitflic.ru