【发布时间】:2017-03-08 21:42:34
【问题描述】:
这是我的 Nginx 配置文件:
upstream app {
server unix:/home/deploy/example_app/shared/tmp/sockets/puma.sock fail_timeout=0;
}
server {
listen 80;
listen 443 ssl;
# ssl on;
server_name localhost example.com www.example.com;
root /home/deploy/example_app/current/public;
ssl_certificate /etc/letsencrypt/live/www.example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/www.example.com/privkey.pem;
try_files $uri/index.html $uri @app;
location / {
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $host;
proxy_redirect off;
proxy_http_version 1.1;
proxy_set_header Connection '';
proxy_pass http://app;
}
location /.well-known { allow all; }
location ~ ^/(assets|fonts|system)/|favicon.ico|robots.txt {
gzip_static on;
expires max;
add_header Cache-Control public;
}
error_page 500 502 503 504 /500.html;
client_max_body_size 4G;
keepalive_timeout 10;
}
证书的路径是正确的,但是当我访问 https://example.com 时,它会一直加载。
我的 SSL 设置有问题吗?
【问题讨论】:
-
为什么 ssl on 被注释掉了?
-
当我取消注释时,我收到此错误:400 Bad Request。纯 HTTP 请求已发送到 HTTPS 端口。
-
正如我在 Nginx 文档中阅读的那样:nginx.org/en/docs/http/configuring_https_servers.html 没有必要这样做。 @j-dexx
标签: ruby-on-rails ssl nginx lets-encrypt