这是我正在使用的代码,我参考了Digital Ocean给出的教程。正如您所看到的,服务器块中有两个位置块,但在输入路径name.com/app时,它将重定向到name.com,我的服务器上有两个应用程序首先在端口3000上运行,另一个在3001上运行,当时我将3001更改为任何端口,令人惊讶的是,它不是重定向,而是提供错误的网关(因为该端口上没有任何内容)。
server{
listen 443 ssl;
server_name name.com www.name.com;
ssl_certificate /etc/letsencrypt/live/name.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/name.com/privkey.pem;
location / {
proxy_pass http://localhost:3000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
location /app {
proxy_pass http://localhost:3001;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
ssl_dhparam /etc/ssl/certs/dhparam.pem;
ssl_ciphers '**STRING**$
ssl_session_timeout 1d;
ssl_session_cache shared:SSL:50m;
ssl_stapling on;
ssl_stapling_verify on;
add_header Strict-Transport-Security max-age=15768000;
}
答案 0 :(得分:0)
正如理查德史密斯在评论中提到的那样,App引发了这个问题。 在3001上运行的应用程序被配置为在出现任何错误时(在生产环境中)重定向到主页(如果发生这种情况下的404)。