у меня проблемы с протоколом HTTP2 на моем сервере NGINX, это моя конфигурация
listen 443 ssl http2;
server_name adomain.com;
root /var/www/project;
limit_req zone=one burst=60 nodelay;
add_header Strict-Transport-Security "max-age=2592000; includeSubdomains;" always;
ssl_certificate /etc/letsencrypt/live/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/privkey.pem;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers "EECDH+AESGCM:EDH+AESGCM:ECDHE-RSA-AES128-GCM-SHA256:AES256+EECDH:DHE-RSA-AES128-GCM-SHA256:AES256+EDH:ECDHE-RSA-AES256-GCM-SHA384:DHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128-SHA:DHE-RSA-AES256-SHA256:DHE-RSA-AES128-SHA256:DHE-RSA-AES256-SHA:DHE-RSA-AES128-SHA:ECDHE-RSA-DES-CBC3-SHA:EDH-RSA-DES-CBC3-SHA:AES256-GCM-SHA384:AES128-GCM-SHA256:AES256-SHA256:AES128-SHA256:AES256-SHA:AES128-SHA:DES-CBC3-SHA:HIGH:!aNULL:!eNULL:!EXPORT:!DES:!MD5:!PSK:!RC4";
ssl_prefer_server_ciphers on;
ssl_session_cache shared:SSL:10m;
ssl_session_timeout 10m;
ssl_dhparam /etc/nginx/ssl/dhparam.pem;
resolver 8.8.8.8;
ssl_stapling on;
ssl_stapling_verify on;
keepalive_timeout 70;
Я не вижу ошибку на своем устройстве iOS (safari 11), очень странно, что веб-страница представляет собой SPA (angular), приложение делает запросы к API, приложения загружаются через HTTP2, но когда приложение должно делать запросы к API не работает, отключая HTTP2 из listen
заставляет все работать как положено
Шифры внешнего и внутреннего интерфейса обоих серверов одинаковы.
В Chrome / Firefox / IE работает нормально, я не знаю, что не так с Safari или конфигурацией моего сервера
Error.log и adomain-error.log пусты, когда Safari не работает.
Версия Nginx
nginx version: nginx/1.12.2
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-16) (GCC)
built with OpenSSL 1.0.2k-fips 26 Jan 2017
TLS SNI support enabled
configure arguments: --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib64/nginx/modules --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx.pid --lock-path=/var/run/nginx.lock --http-client-body-temp-path=/var/cache/nginx/client_temp --http-proxy-temp-path=/var/cache/nginx/proxy_temp --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp --http-scgi-temp-path=/var/cache/nginx/scgi_temp --user=nginx --group=nginx --with-compat --with-file-aio --with-threads --with-http_addition_module --with-http_auth_request_module --with-http_dav_module --with-http_flv_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_mp4_module --with-http_random_index_module --with-http_realip_module --with-http_secure_link_module --with-http_slice_module --with-http_ssl_module --with-http_stub_status_module --with-http_sub_module --with-http_v2_module --with-mail --with-mail_ssl_module --with-stream --with-stream_realip_module --with-stream_ssl_module --with-stream_ssl_preread_module --with-cc-opt='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -m64 -mtune=generic -fPIC' --with-ld-opt='-Wl,-z,relro -Wl,-z,now -pie'
ОБНОВИТЬ
Консоль на моем iPhone говорит Protocol error
так что я почти уверен, что это ошибка IOS 11
ОБНОВЛЕНИЕ 2
Я нашел этот пост
https://www.nginx.com/blog/http2-theory-and-practice-in-nginx-stable-13/
Он объясняет, что если вы поддерживаете TLSv <1.2, вы попадете в PROTOCOL ERROR
, оставив в моей конфигурации сервера только TLSv1.2, приложение снова работает, но оно глючит, некоторые запросы не работают ... это вне моего понимания, снова в Chrome / Firefox он работает, но в моем мобильном сафари это не так
ОБНОВЛЕНИЕ 3 [2019/02/28]
В нашей конфигурации NGINX для метода OPTIONS запроса CORS была ошибка, вызывающая дублирование Content-Length и Тип содержимого заголовки, на которые нужно ответить, после того как мы выяснили, что приложение начало нормально работать в HTTP / 2, мы также изменили статус ответа OPTIONS с 200 на 204
Не уверен, что это все еще проблема, и это может не относиться к NGINX так же, как к Apache, но Apache автоматически добавляет Upgrade
заголовки, которые заставили клиентов, не поддерживающих HTTP / 2, заставить себя сделать это (как видно из этого билет об ошибке) - Так что я бы перепроверил, не происходит ли этого и на этом сервере. На данный момент любые другие проблемы HTTP / 2 должны были быть устранены в обновлениях iOS 11.
EDIT: обходной путь заключался в том, чтобы вручную удалить эти заголовки в Apache. Надеюсь, это поможет вам выбрать направление для nginx.
У меня возникла аналогичная проблема, я использую Apache в Windows 2008 R2 с h2
включен для всех виртуальных хостов и использует mod_http2
, iOS 11 не может должным образом взаимодействовать с сервером, что приводит к ошибке протокола. Исправление - просто отключить http2
на стороне сервера или вернуться к http
в отличие от https
.