ssl_session_ticket_key and SNI
Maxim Dounin
mdounin at mdounin.ru
Fri May 9 06:36:43 UTC 2014
Hello!
On Tue, May 06, 2014 at 03:46:36PM +0400, Anton Yuzhaninov wrote:
> Здравствуйте!
>
> Наблюдаю проблему с таким конфигом:
>
> http {
> default_type text/plain;
>
> access_log logs/access.log combined;
>
>
> server {
> server_name example.ru;
> listen 443 default;
>
> ssl on;
> ssl_certificate example.ru.crt;
> ssl_certificate_key example.ru.key;
>
> ssl_session_ticket_key ticket.key;
>
> location / {
> return 200 "example.ru\n";
> }
> }
>
> server {
> server_name example.com;
> listen 443;
>
> ssl on;
> ssl_certificate example.com.crt;
> ssl_certificate_key example.com.key;
>
> location / {
> return 200 "example.com\n";
> }
> }
> }
>
> Желаемое поведение:
> - для example.ru использовать ticket key из файла.
> - для example.com (и всех остальных блоков server) использовать случайный
> ticket key, генерируемый в nginx при старте.
>
> Что наблюдается:
> - Без SNI работает и отдается сертификат example.ru
> - Если в SNI указать example.ru - работает и отдается сертификат example.ru
> - Если в SNI указать example.com - соединение рвётся с очень неясной диагностикой.
> - Если в SNI указать example.com, но отключить tickets на клиенте - работает.
>
> Версии
> nginx 1.7.0
> OpenSSL 1.0.1g-freebsd 7 Apr 2014
>
> Если убрать ssl_session_ticket_key задавать на уровне http, то всё работает.
> Но хочется брать tickets из файла только для одного сервера.
В OpenSSL всё очень плохо в части кеширования сессий (что с
тикетами, что без) при использовании SNI. Когда я последний раз
на это смотрел - ушёл из кода OpenSSL с желанием это развидеть, и
стойким ощущением, что не надо искать неприятностей и пытаться
делать разные настройки кеширования в разных SNI-серверах.
--
Maxim Dounin
http://nginx.org/
Подробная информация о списке рассылки nginx-ru