Переадресация Nginx в инстанс EC2 - PullRequest
0 голосов
/ 23 апреля 2019

У меня был сайт Angular (версия: 7), который был развернут на корзине S3, но для целей SEO я недавно интегрировал Angular Universal .

Теперь я переместил сайт / интерфейс из корзины S3 в экземпляр EC2. Я пытаюсь развернуть мое угловое универсальное приложение на Nginx (версия: nginx / 1.14.1) на моем экземпляре EC2 (CentOS).

Поток идет примерно так: доменное имя (example.com/www.example.com) зарегистрировано на godaddy, которое указывает на Cloud Front, который отправляет / пересылает мой запрос в экземпляр EC2 (сервер Nginx).

Issue

Всякий раз, когда я пытаюсь нажать на 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

EC2 Security Group

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, но пока не повезло. Кто-нибудь может помочь?

1 Ответ

0 голосов
/ 23 апреля 2019
server {
    listen 80;
    listen [::]:80;

    server_name yourdomaim.com;

    location / {
                proxy_pass http://localhost:5200;
                proxy_http_version 1.1;
                proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection 'upgrade';
                proxy_set_header Host $host;
                proxy_set_header X-Forwarded-For $remote_addr;
                proxy_set_header  X-Real-IP  $remote_addr;
                proxy_cache_bypass $http_upgrade;
        }
}

Вы должны запустить свой угловой универсальный проект на порту 5200, используя такие инструменты, как pm2, если вы используете nodeJS. А настройки про должны работать в nginx

...