我正在开发一个nodejs应用程序,我希望这个应用程序可以通过nginx的两个域(两个域指向同一个应用程序)访问,该应用程序部署在DigitalOcean droplet上,因此
假设我有我的app::port
和域名一: example1.com
和第二个域: example2.com
我遵循了为一个域设置ssl的所有步骤,并对第二个域执行了相同的操作,下面是我的配置文件(它们在sites-available中):config example1.com
`server {
listen 443 ssl;
server_name example1.com;
ssl_certificate /etc/nginx/ssl-1/example1.com.crt;
ssl_certificate_key /etc/nginx/ssl-1/example1.com.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 http://127.0.0.1:3000;
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;
}
}`配置example2.com
`
server {
listen 443 ssl;
server_name example2.com;
ssl_certificate /etc/nginx/ssl-2/example2.com.crt;
ssl_certificate_key /etc/nginx/ssl-2/example2.com.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 http://127.0.0.1:3000;
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;
}
}`example11.com工作正常,但example2.com不工作,google chrome给出此警告

基本上,它是说example2.com的证书是为example1.com颁发的。
所以任何人都有在nginx上使用ssl为同一应用程序设置两个域的经验,请帮助我。
发布于 2018-10-22 06:58:59
在一遍又一遍地重复所有步骤后,我发现我所做的一切都是正确的,只有一件事我遗漏了:
我忘记了第二个域的站点启用文件。
ln -s /etc/nginx/sites-available/example2 /etc/nginx/sites-enabled/example2
在那之后,一切都很好。
发布于 2018-10-22 06:35:58
如果它指向同一个应用程序,你能重定向吗?如果是这样的话,试试这个:
server {
server_name example2.com;
return 301 https://example1.com;
}https://stackoverflow.com/questions/52920442
复制相似问题