试图弄清楚如何设置 NGINX 以在同一主机上为多个站点提供服务,并使用子文件夹统一配置。尝试拥有mydomain.com/blue
并mydomain.com/red
服务于 2 个不同的 NodeJS 网站。
到目前为止,我这样做了:2个配置,其中sites-availables
包含符号链接sites-enables
它们都具有相同的配置,除非对于上游,我更改名称和端口。
# path: /etc/nginx/sites-available/blue.conf
# Server
upstream blue {
server 127.0.0.1:1337;
}
server {
# Listen HTTP
listen 80;
server_name mydomain.com;
# Redirect HTTP to HTTPS
return 301 https://$host$request_uri;
}
server {
# Listen HTTPS
listen 443 ssl http2;
server_name mydomain.com;
# SSL config
ssl_certificate /etc/letsencrypt/live/mydomain.com/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/mydomain.com/privkey.pem; # managed by Certbot
include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
# Static Root
location / {
root /var/www;
}
# API and Admin
location /blue/ {
rewrite ^/blue/?(.*)$ /$1 break;
proxy_pass http://blue/;
proxy_http_version 1.1;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_pass_request_headers on;
}
}
对于另一个conf,这些差异是相同的:
# Server
upstream red {
server 127.0.0.1:2160;
}
# API and Admin
location /red/ {
rewrite ^/red/?(.*)$ /$1 break;
proxy_pass http://red/;
...
}
它目前无法正常工作,在设置第二个站点并重新加载 nginx 后,我得到了一个403 forbidden
或第一个,第二个可以工作
有什么线索吗?