【问题标题】:Serving two websites with the same Nginx on the same ubuntu server redirect to same website在同一个 ubuntu 服务器上使用相同的 Nginx 服务两个网站重定向到同一个网站
【发布时间】:2019-04-23 15:10:41
【问题描述】:

我试图在我的 Ubuntu 16.04 服务器上为两个不同的网站提供服务。

这是/etc/nginx/sites-available/website1.com中的Website1配置:

server {
        listen 80;
        listen [::]:80;

        server_name website1.com www.website1.com;
        return 301 https://$server_name$request_uri;
}

server {
        listen 443 ssl;

        server_name website1.com www.website1.com;
        ssl_certificate /etc/nginx/ssl/website1.com.domain.crt;
        ssl_certificate_key /etc/nginx/ssl/website1.com.intermediate.key;

        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_prefer_server_ciphers on;
        ssl_ciphers 'EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH';

        location / {
                proxy_pass https://127.0.0.1:1337;
                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;
        }
}

这是/etc/nginx/sites-available/website2.com中的Website2配置:

server {
        listen 80;
        listen [::]:80;

        server_name website2.com www.website2.com;
        return 301 https://$server_name$request_uri;
}

server {
        listen 443 ssl;

        server_name website2.com www.website2.com;
        ssl_certificate /etc/nginx/ssl/website2.com.domain.crt;
        ssl_certificate_key /etc/nginx/ssl/website2.com.intermediate.key;

        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_prefer_server_ciphers on;
        ssl_ciphers 'EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH';

        location / {
                proxy_pass https://127.0.0.1:5000;
                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;
        }
}

我尝试使用nginx 服务的这两个网站是两个nodejs 应用程序。一个监听端口1337 (website1),一个监听端口5000 (website2)。

如果我访问 URL https://website1.com,我会访问正确的网站,即 website1

如果我访问 url https://website2.com 我访问了错误的网站,它会显示 website1,而不是 website2。 (顶部栏的网址是http://website2.com,带有SSL 的警告)。

如何在同一个 Ubuntu 服务器上使用同一个 nginx 服务为两个不同的网站提供服务?

【问题讨论】:

  • 您的/etc/nginx/sites-enabled 目录中有什么? :)
  • sites-available 中的链接文件:website1.comwebsite2.com。我做了这个命令ln -s /etc/nginx/sites-available/website1.com /etc/nginx/sites-enabled/website2.com 相同
  • 可能看起来很傻,但是您是否重新启动/重新加载了 nginx sudo service nginx reload 来告诉它使用您的“新”配置文件? sudo nginx -t 也是在您的配置文件中发现错误的赢家。
  • 当然,我做了这些步骤......我认为这可能是 SSL 证书的问题......奇怪的是,如果我从配置中删除 listen 443 部分,我每次都会被重定向website1.

标签: node.js ubuntu nginx


【解决方案1】:

重定向问题是由于无效的SSL 证书造成的。我正在尝试弄清楚如何使其有效。

那么,nginx 配置就可以了。

【讨论】:

    猜你喜欢
    • 2018-07-25
    • 2013-07-16
    • 1970-01-01
    • 2012-07-30
    • 2014-02-07
    • 1970-01-01
    • 1970-01-01
    • 2023-03-31
    • 2020-04-08
    相关资源
    最近更新 更多