node.js - Nginx 配置:一个 nodeJS 应用程序的两个域名
问题描述
我正在开发一个nodejs应用程序,我希望这个应用程序可以通过nginx的两个域(两个域指向同一个应用程序)访问,该应用程序部署在DigitalOcean droplet上,所以
假设我有我的应用程序: :port
和域一:example1.com
和域二:example2.com
我按照所有步骤为一个域设置 ssl,对第二个域也做了同样的操作,这是我的配置文件(它们位于可用站点中):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 不工作,谷歌浏览器给出这个警告
基本上,就是说example2.com的证书是为example1.com颁发的。
所以任何人都有在 nginx 上为同一个应用程序设置两个域的经验帮助我。
解决方案
在一遍又一遍地重做所有步骤之后,我发现我所做的一切都是正确的,只是我错过了一件事情:
我忘记了第二个域的启用站点的文件。
ln -s /etc/nginx/sites-available/example2 /etc/nginx/sites-enabled/example2
之后一切正常
推荐阅读
- vb.net - 以管理员身份运行带有提升标志的命令(使用已知密码)
- php - 如何处理内部联接和与 OOP 的一对多关系?
- r - 随机化 data.frame 多列中的值
- c# - unity如何自定义控制台窗口
- html - 如何在订阅角度方法调用(按钮单击)中将 html 字符串响应显示为 Pdf
- ios - Alamofire:使用 Swift 4.2.1 编译的模块不能被 Swift 5.0 编译器导入
- xcode - 如何运行 Xcode 10.2 模拟器
- python - 如何根据该行的第 1 列与该行的第 2 列相比,给某些行“点”
- javascript - 打字机功能
- javascript - 为什么在 JavaScript 中比较一个数组和一个数字这么慢?它在做什么?