Настройка nginx для поддержки SSL
Настройка nginx для поддержки SSL
Для настройки nginx нужно:
- создать новый пустой сниппет nginx в каталоге
/etc/nginx/snippets
для указания размещения сертификата и ключа:
sudo touch /etc/nginx/snippets/self-signed.conf
- отредактировать созданный файл, приведя его к виду:
ssl_certificate /etc/ssl/certs/nginx-selfsigned.crt; ssl_certificate_key /etc/ssl/private/nginx-selfsigned.key;
- создать еще один пустой сниппет, предназначенный для настроек SSL (это позволит серверу nginx использовать надежный механизм преобразования и включит некоторые дополнительные функции безопасности):
sudo touch /etc/nginx/snippets/ssl-params.conf
- отредактировать созданный файл
ssl-params.conf
, приведя его к виду:
ssl_protocols TLSv1.3; ssl_prefer_server_ciphers on; ssl_dhparam /etc/nginx/dhparam.pem; ssl_ciphers ECDHE-RSA-AES256-GCM-SHA512:DHE-RSA-AES256-GCM-SHA512:ECDHE-RSA-AES256-GCM-SHA384:DHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-SHA384; ssl_ecdh_curve secp384r1; # Requires nginx >= 1.1.0 ssl_session_timeout 10m; ssl_session_cache shared:SSL:10m; ssl_session_tickets off; # Requires nginx >= 1.5.9 ssl_stapling on; # Requires nginx >= 1.3.7 ssl_stapling_verify on; # Requires nginx => 1.3.7 resolver 77.88.8.8 77.88.8.1 valid=300s; resolver_timeout 5s; # Disable strict transport security for now. You can uncomment the following # line if you understand the implications. # add_header Strict-Transport-Security "max-age=63072000; includeSubDomains; preload"; add_header X-Frame-Options DENY; add_header X-Content-Type-Options nosniff; add_header X-XSS-Protection "1; mode=block";
Поскольку сертификат является самоподписанным, SSL stapling
не будет использоваться. Сервер nginx выдаст предупреждение, отключит stapling
для данного сертификата и продолжит работу.