В настоящее время я использую сервер Ubuntu 16.04.1 LTS, используя NGINX 1.11.9 и openssl 1.0.2g.
В соответствии со всем, что я прочитал, эти версии должны поддерживать ALPN, но когда я запускаю тест на инструменте HTTP / 2 KeyCDN Test , я получаю «ALPN не поддерживается»
И когда я выполняю echo | openssl s_client -alpn h2 -connect example.com:443 | grep ALPN
, я получаю:
depth=3 C = SE, O = AddTrust AB, OU = AddTrust External TTP Network, CN = AddTrust External CA Root
verify return:1
depth=2 C = GB, ST = Greater Manchester, L = Salford, O = COMODO CA Limited, CN = COMODO RSA Certification Authority
verify return:1
depth=1 C = GB, ST = Greater Manchester, L = Salford, O = COMODO CA Limited, CN = COMODO RSA Domain Validation Secure Server CA
verify return:1
depth=0 OU = Domain Control Validated, OU = EssentialSSL Wildcard, CN = *.example.com
verify return:1
No ALPN negotiated
DONE
Отключение ALPN отключает HTTP2 от полного включения. Как включить ALPN?
РЕДАКТИРОВАТЬ
nginx -V
шоу:
nginx version: nginx/1.11.9
built by gcc 4.8.4 (Ubuntu 4.8.4-2ubuntu1~14.04.3)
built with OpenSSL 1.0.1f 6 Jan 2014 (running with OpenSSL 1.0.2g 1 Mar 2016)
TLS SNI support enabled
configure arguments: --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib/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='-g -O2 -fstack-protector --param=ssp-buffer-size=4 -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fPIC' --with-ld-opt='-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now -Wl,--as-needed -pie'
РЕДАКТИРОВАТЬ № 2
openssl version -a
вывод:
OpenSSL 1.0.2h 3 May 2016
built on: reproducible build, date unspecified
platform: linux-x86_64
options: bn(64,64) rc4(16x,int) des(idx,cisc,16,int) idea(int) blowfish(idx)
compiler: gcc -I. -I.. -I../include -DOPENSSL_THREADS -D_REENTRANT -DDSO_DLFCN -DHAVE_DLFCN_H -Wa,--noexecstack -m64 -DL_ENDIAN -O3 -Wall -DOPENSSL_IA32_SSE2 -DOPENSSL_BN_ASM_MONT -DOPENSSL_BN_ASM_MONT5 -DOPENSSL_BN_ASM_GF2m -DSHA1_ASM -DSHA256_ASM -DSHA512_ASM -DMD5_ASM -DAES_ASM -DVPAES_ASM -DBSAES_ASM -DWHIRLPOOL_ASM -DGHASH_ASM -DECP_NISTZ256_ASM
OPENSSLDIR: "/usr/local/ssl"
built with OpenSSL 1.0.1f
- угадай, что ответopenssl version -a
, чтобы мы могли видеть, был ли ваш OpenSSL собран с неожиданными флагами / опциями?Ответы:
Как указал @AlexyTen, основная причина заключалась в том, что, хотя у меня был установлен OpenSSL 1.0.2g, NGINX нужно было собирать с OpenSSL, а он был построен с 1.0.1f, который не поддерживает ALPN.
NGINX должен быть перестроен с OpenSSL 1.0.2 или выше и переустановлен. Я нашел несколько учебных пособий в Интернете, но поскольку я использую сервер Digital Ocean, я воспользовался этим разделом справки, чтобы решить эту проблему для меня: https://www.digitalocean.com/community/questions/how-to-get-already- установлен-Nginx в использовании-OpenSSL-1-0-2-для-alpn
Сначала мне нужно было установить несколько новых библиотек:
Затем я просто запустил этот скрипт: https://gist.github.com/AJMaxwell/f6793605068813aae888216b02364d85
Я перезапустил использование
sudo shutdown -r now
иnginx -V
снова побежал . На этот раз это дало мне:Я также снова запустил http2-тест keycdn, и он прошел.
источник
Я создал скрипт bash, который автоматически загружает, компилирует и устанавливает Nginx с OpenSSL в Debian / Ubuntu, RHEL / CentOS и других дистрибутивах. Полученный двоичный файл точно такой же, как тот, который распространяет Nginx через его официальный репозиторий, за исключением того, что он поставляется с последней версией OpenSSL.
Сценарий не изменяет установку OpenSSL, только двоичный файл Nginx. Это хороший вариант, если вы не хотите полагаться на пакеты, созданные и распространяемые неофициальными источниками.
https://github.com/victordzmr/nginx-compiler
источник
Установите nginx ppa, и он будет поддерживать ALPN:
источник
hda-me/nginx-stable
тем, чтобы вы могли запускать brotli и динамические модули