Tente adicionar default_server à estrofe do servidor que você mostrou:
server {
listen 443 default_server ssl;
server_name example.com;
root /srv/web;
...
Não se esqueça de reiniciar.
Eu configurei o nginx 1.4.1 para usar tls / ssl usando um certificado autoassinado. Eu posso conectar via https usando apenas o endereço IP da LAN. Eu também posso conectar-me ao server_name
, mas somente através de http e ele exibe apenas o 'Bem-vindo ao nginx!' página. Alguma idéia de como obter https com o server_name
? ( nginx.conf
é apenas o padrão).
$ cat /etc/nginx/sites-available/example.conf
server {
listen 443 ssl;
server_name example.com;
root /srv/web;
ssl_certificate /srv/server.crt;
ssl_certificate_key /srv/server.key;
ssl_protocols SSLv3 TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers RC4:HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
location / {
proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
proxy_pass http://127.0.0.1:8000;
}
location ~ /\. {
deny all;
}
}
Edit: Importa que eu esteja no subdomínio de outra pessoa (livre / público)? Eu sei que para obter um certificado assinado por uma CA, você precisaria de prova de propriedade de domínio, mas não deveria importar para o nginx no meu caso de uso, certo?
Tente adicionar default_server à estrofe do servidor que você mostrou:
server {
listen 443 default_server ssl;
server_name example.com;
root /srv/web;
...
Não se esqueça de reiniciar.
Você tem um link simbólico em /etc/nginx/sites-enabled
para o arquivo de configuração em /etc/nginx/sites-available
?
O nginx só lê arquivos de configuração em /etc/nginx/sites-enabled
.