Nginx SSL não consegue se conectar ao site

Nginx SSL não consegue se conectar ao site

Acabei de comprar um certificado SSL para o meu site e tentei fazê-lo funcionar com a instalação do nginx, mas após a conexão, o navegador recusa a conexão com o site. Aqui está a parte relevante do Vhost:

     server {
          listen 80;
          listen [::]:80;
           server_name mysite.be www.mysite.be;
           return 301 https://mysite.be$request_uri;
        }

    server {

       listen 443 ssl spdy;
        listen [::]:443 ssl spdy;

        ssl_certificate /etc/nginx/ssl/mysite.be/www.mysite.be.pem;
        ssl_certificate_key /etc/nginx/ssl/mysite.be/mysite.be.key;
        ssl_protocols  TLSv1 TLSv1.1 TLSv1.2;   # don.t use SSLv3 because of the POODLE attack

       # Enable OCSP Stapling, point to certificate chain
       ssl_stapling on;
       ssl_stapling_verify on;
          # Tell the browser we do SPDY
         # add_header        Alternate-Protocol  443:npn-spdy/2;


            server_name mysite  *.mysite.be;

[.....]

A configuração que você vê acima

A parte nginx.conf:

ssl_prefer_server_ciphers on;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers "EECDH+ECDSA+AESGCM EECDH+aRSA+AESGCM EECDH+ECDSA+SHA384 EECDH+ECDSA+SHA256 EECDH+aRSA+SHA384 EECDH+aRSA+SHA256 EECDH+aRSA+RC4 EECDH EDH+aRSA !RC4 !aNULL !eNULL !LOW !3DES !MD5 !EXP !PSK !SRP !DSS";

ssl_stapling on;
ssl_stapling_verify on;
resolver 8.8.4.4 8.8.8.8 valid=300s;
resolver_timeout 10s;

ssl_session_cache shared:SSL:32m;
ssl_buffer_size 8k;
ssl_session_timeout 10m;

Não sei o que fiz de errado, segui muitos tutoriais para chegar a esse ponto e simplesmente não funciona.

Responder1

A primeira configuração do servidor é um redirecionamento para HTTPS (segunda configuração).

Na configuração do segundo servidor o módulo SPDY não é construído por padrão, deve ser habilitado com o --with-http_spdy_moduleparâmetro de configuração. Observe que para aceitar conexões HTTPS e SPDY simultaneamente na mesma porta, a biblioteca OpenSSL usada deve suportar a extensão TLS “Next Protocol Negotiation”, disponível desde a versão 1.0.1 do OpenSSL (referência aqui).

Eu escreveria a segunda configuração do servidor desta forma (PoC):

server {
  listen       443;
  server_name  .mysite.be;

  ssl                  on;
  ssl_certificate      /etc/nginx/ssl/mysite.be/www.mysite.be.pem;
  ssl_certificate_key  /etc/nginx/ssl/mysite.be/mysite.be.key;

  ssl_session_timeout  5m;

  ssl_protocols  SSLv2 SSLv3 TLSv1;
  ssl_ciphers  ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
  ssl_prefer_server_ciphers   on;

  root [YOUR_ROOT_DIR]
  ...
}

No nginx.confeu omitiria todas as coisas relacionadas ao SSL e o manteria por padrão.

informação relacionada