【发布时间】: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.com和website2.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.