- Вам не хватает сертификатов TLS, поэтому даже если вы настроите перенаправление, браузер будет отвечать только ошибкой сертификата.
Вы должны настроить
ssl_certificate
и ssl_certificate_key
директивы
И вы должны указать ssl и http2 в директиве прослушивания для HTTP/2
Для HTTP/3 http3 подразумевает обязательный ssl, поэтому нет ssl в этом случае должна быть указана директива.
Ваша конфигурация имеет бесконечный цикл перенаправления, который делает сервер непригодным для использования.
Особенно вы бесконечно перенаправляете на HTTPS.
На вашем сервере отсутствует поддержка IPv6.
Вы должны сделать что-то вроде этого:
сервер {
слушать 0.0.0.0:80 default_server;
слушать [::]:80 default_server;
место расположения / {
вернуть 308 https://$host$request_uri/something;
}
}
сервер {
слушать 0.0.0.0:443 повторно использовать порт http3;
слушать 0.0.0.0:443 http2 ssl;
слушать [::]:443 http3 reuseport;
слушать [::]:443 http2 ssl;
имя_сервера $ВАШ ДОМЕН;
ssl_certificate $CERT_PATH;
ssl_certificate_key $CERT_KEY;
[...]
}
См. также инструмент настройки Mozilla TLS, который поможет вам:
https://ssl-config.mozilla.org/
И настроить его под свои нужды.
Примечание. Приведенные выше строки конфигурации, относящиеся к http3, полезны только в том случае, если вы компилируете NGINX с поддержкой HTTP/3, которая доступна только в ветке nginx-quic.