Здравствуйте,
Простите за, возможно, глупый вопрос.
Правильно ли я понимаю, что для выключения ДХ в nginx необходимо только выключить ssl_dhparams?
Или же, нужно в ssl_ciphers выпилить все ECDHE и DHE?

Best Regards
Sergey Komarov

28.11.2018 20:06, Maxim Dounin пишет:
Hello!

On Wed, Nov 28, 2018 at 06:20:12PM +0200, Vladimir Getmanshchuk wrote:

Странная ситуация с SSL - жуткий лаг на отдаче:


# curl -w "time_connect: %{time_connect}\ntime_total: %{time_total}\n" -X
GET -s -q http://1.1.1.1/google663dfea033864f54.html -o /dev/null

time_connect: 0.000

time_total: 0.001


# curl -w "time_connect: %{time_connect}\ntime_total: %{time_total}\n" -X
GET -s -q https://1.1.1.1/google663dfea033864f54.html --insecure -o
/dev/null

time_connect: 0.000

time_total: *0.106*
В SSL есть операция SSL handshake, и в зависимости от используемых
шифров и сертификатов - она может занимать как просто много
времени, так и очень много времени.  (Ну и поскольку curl между
запусками не может сохранять ранее установленную сессию - каждый
запуск будет требовать полного handshake'а.)

В частности, если вдруг используется обмен ключами с помощью
алгоритма Диффи-Хеллмана - будет тормозить.  Особенно если задать
параметры где-нибудь на 4096 бит.  Смотрите внимательно, что
именно за шифры у вас используются, и если DHE - то что именно у
вас лежит в ssl_dhparam.  Ну или просто уберите ssl_dhparam из
конфига - по умолчанию nginx просто не будет использовать DHE.

Кроме того, будет тормозить, если используются RSA-сертификаты
больше 2048 бит.  Смотрите, что за сертификат используется.
RSA-сертификаты на 4096 бит - зачастую по умолчанию прилетают из
модных и молодёжных инструментов получения сертификатов от
LetsEncrypt, но малопригодны для работы web-сервера.


_______________________________________________
nginx-ru mailing list
[email protected]
http://mailman.nginx.org/mailman/listinfo/nginx-ru

Ответить