【发布时间】:2021-12-17 15:50:51
【问题描述】:
试图弄清楚如何设置 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;
}
}
对于其他配置,这些差异相同:
# 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 或第一个,第二个可以工作
有什么线索吗?
【问题讨论】:
-
/var/log/nginx/...中显示的错误日志是什么? -
它说
directory index of "/var/www/blue/" is forbidden我检查了权限,一切似乎都很好,chown www-data:www-data和chmod 755用于文件夹,644用于文件。还在location中尝试了autoindex on;,但没有多大帮助这里奇怪的是,如果我从sites-enabled中删除其中一个conf,两个网站都独立工作,但是当我启用了2 个conf 时,其中一个会得到403 forbidden
标签: nginx nginx-upstreams