Я хочу разместить 2 сайта на 1 сервере (чтобы сэкономить деньги, мой сервер в любом случае использует только 2% CPU в любое время). Месяц назад я столкнулся с проблемой, когда Google отображал мой IP вместо домена в результатах поиска, поэтому я добавил перенаправление catchall. Когда я пытаюсь разместить свой example2.com, catchall всегда срабатывает и перенаправляет на example1.com.
example1.com важнее; example2.com — это скорее сторонний проект, поэтому я хочу, чтобы все перенаправлялось на example1.com. Проблема в том, что example2.com (http и https) также перенаправляется на example1.com.
# Catchall configuration - redir to the domain for bare and invalid domain requests
server {
listen 80 default_server;
server_name _;
return 301 https://example1.com$request_uri;
}
# HTTPS for example1.com
server {
listen 443 ssl;
server_name example1.com;
ssl_certificate /etc/letsencrypt/live/example1.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/example1.com/privkey.pem;
location / {
proxy_pass http://localhost: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
server {
listen 80 ;
server_name example2.com www.example2.com;
return 301 https://example2.com$request_uri;
}
server {
listen 443 ssl;
server_name example2.com www.example2.com;
ssl_certificate /etc/letsencrypt/live/example2.com/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/example2.com/privkey.pem; # managed by Certbot
include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
location / {
proxy_pass http://localhost:4000;
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;
}
}