Ngnix:在具有多个 IP 地址的服务器上使用共享 IP 的多个网站

问题描述

我正在将多个网站部署到配备 Nginx 的 Ubuntu 服务器。我还使用 proxy_pass 功能将流量传递给服务。

问题是无论哪个网站先在 Nginx 上设置,所有传入的流量都会重新路由到。

我在 .conf 中创建了 3 个不同的 /etc/Nginx/conf 文件,以下是每个文件的详细信息:

  • subdomain1.conf
server {
listen       <the second ip>:80;
server_name  subdomain1.mydomain.com;

location / {
        proxy_pass         http://127.0.0.1:11111;
        proxy_http_version 1.1;
        proxy_set_header   Upgrade $http_upgrade;
        proxy_set_header   Connection keep-alive;
        proxy_set_header   Host $host;
        proxy_cache_bypass $http_upgrade;
        proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header   X-Forwarded-Proto $scheme;
    }
}
  • subdomain2.conf
server {
listen       <the second ip>:80;
server_name  subdomain2.mydomain.com;

location / {
        proxy_pass         http://127.0.0.1:22222;
        proxy_http_version 1.1;
        proxy_set_header   Upgrade $http_upgrade;
        proxy_set_header   Connection keep-alive;
        proxy_set_header   Host $host;
        proxy_cache_bypass $http_upgrade;
        proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header   X-Forwarded-Proto $scheme;
    }
}
  • subdomain3.conf
server {
listen       <the second ip>:80;
server_name  subdomain3.mydomain.com;

location / {
        proxy_pass         http://127.0.0.1:33333;
        proxy_http_version 1.1;
        proxy_set_header   Upgrade $http_upgrade;
        proxy_set_header   Connection keep-alive;
        proxy_set_header   Host $host;
        proxy_cache_bypass $http_upgrade;
        proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header   X-Forwarded-Proto $scheme;
    }
}

最后,我使用以下命令行重新加载 Nginxsudo Nginx -s reload

但是,其他子域(子域 2 和子域 3)的所有传入流量都以某种方式传递到子域 1。到目前为止我注意到的是,无论哪个先设置,所有传入的流量都绑定到它。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)