首页 > 解决方案 > 如何使用 nginx 将不同的子域重定向到在不同端口上运行的应用程序

问题描述

我在端口 3000 和 1337 的 EC2 实例中运行了 2 个 nodejs 应用程序。我想要实现的是

admin.mydomain.com

应该重定向到在 PORT 1337 上运行的应用程序和

mydomain.com www.mydomain.com

应该重定向到在 PORT 3000 上运行的应用程序。

使用我当前的 nginx 配置,我得到一个 502

  map $subdomain $subdomain_port {
  default    3000;
  www        3000;
  admin      1337;
}

server {
listen 80;
listen [::]:80;
server_name _;
return 301 https://$server_name$request_uri;
}

server {
listen 443 ssl http2 default_server;
listen [::]:443 ssl http2 default_server;
server_name ~^(?P<subdomain>.+?)\.historydiaries\.com$;

location / {
proxy_pass http://localhost:$subdomain_port;
proxy_redirect off;
}

ssl_certificate /etc/letsencrypt/live/historydiaries.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/historydiaries.com/privkey.pem;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
ssl_ciphers EECDH+CHACHA20:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5;

ssl_session_cache shared:SSL:5m;
ssl_session_timeout 1h;
add_header Strict-Transport-Security “max-age=15768000” always;
}

标签: sslnginxreverse-proxylets-encrypt

解决方案


我将使用单独的 Nginx vhost 配置。

一个用于www.mydomain.com,另一个用于 admin.mydomain.com

server {
    listen 80;
    server_name www.mydomain.com;
    access_log /var/log/nginx/mydomain_access.log;

    location / {
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;

        proxy_pass http://localhost:3000/;
        proxy_redirect off;
    }
}

server {
    listen 80;
    server_name admin.mydomain.com;
    access_log /var/log/nginx/admin.mydomain_access.log;

    location / {
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;

        proxy_pass http://localhost:1337/;
        proxy_redirect off;
    }
}

这只是简单的虚拟主机配置。您可以稍后在需要时添加 Let's Encrypt。


推荐阅读