У меня был сайт angular (версия: 7), который был развернут в ведре S3, но для целей SEO недавно я интегрировал Угловой Универсальный.
Теперь я переместил сайт / интерфейс из сегмента S3 в экземпляр EC2. Я пытаюсь развернуть свое универсальное приложение angular на Nginx (версия: nginx / 1.14.1) на моем экземпляре EC2 (CentOS).
Поток идет примерно так: имя домена (example.com/www.example.com) зарегистрировано на godaddy, что указывает на Cloud Front, который отправляет / перенаправляет мой запрос в экземпляр EC2 (сервер Nginx).
Проблема
Всякий раз, когда я пытаюсь попасть по URL https://example.com или https://www.example.com, они были перенаправлены на адрес экземпляра EC2, например https://ec2-xx-xxx-xxx-xx.region-x.compute.amazonaws.com/ .
Кто-то понял, что это связано с конфигурацией сервера, как указано Вот
При подключении через CloudFront убедитесь, что сервер не перенаправляет вас обратно на имя хоста EC2 или IP (адресная строка в браузере изменится, если это произойдет, и вы захотите исправить конфигурацию своего веб-сервера, если что происходит).
Похоже, у меня проблема с конфигурацией nginx. Ниже приведены использованные мною конфутации.
Настройки группы безопасности EC2
nginx.conf
upstream nrc_frontend_nodejs {
server 127.0.0.1:4000;
}
server {
listen 80 default_server;
listen [::]:80 default_server;
server_name _;
return 301 https://$host$request_uri;
}
server {
listen 443 ssl http2 default_server;
listen [::]:443 ssl http2 default_server;
server_name example.com www.example.com;
ssl_certificate ssl/example.chained.crt;
ssl_certificate_key ssl/example.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
ssl_ciphers 'CEMDH+ATSGCM:EDH+AESGCG:AES256+EECDH:AES256+EDH';
root /home/ec2-user/nginx/dist; # <-- Static Resources
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
location / {
try_files $uri $uri @backend; # <--- This looks for requests (statics i.e js/css/fonts)
# in /ssr/dist folder. If nothing found, calls @backend (running at 127.0.0.1:4000)
}
location @backend {
proxy_pass http://nrc_frontend_nodejs;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_http_version 1.1;
proxy_set_header X-NginX-Proxy true;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_cache_bypass $http_upgrade;
proxy_redirect off;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_pass_request_headers on;
}
}
Прошло пару дней, я пробовал много разных способов настроить nginx, но пока безуспешно. Кто-нибудь может помочь?
Я еще больше упростил файл nginx.conf. Просто указываю на статическую html-страницу nginx по умолчанию (без обратного прокси, без причудливых конфигураций)
nginx.conf
server {
listen 80;
listen [::]:80;
server_name _;
return 301 https://$host$request_uri;
}
server {
listen 443 ssl http2 default_server;
listen [::]:443 ssl http2 default_server;
server_name example.com www.example.com;
ssl_certificate ssl/example.chained.crt;
ssl_certificate_key ssl/example.key;
root /usr/share/nginx/html;
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
location / {
}
}
Но все же всякий раз, когда я ударил https://www.example.com он перенаправляется на экземпляр EC2, а затем показывает значение по умолчанию для nginx index.html
файл.
Я не уверен, что это проблема Nginx или проблема AWS (CloudFront или EC2). Может ли кто-нибудь сообщить мне решение?