Nginx 重定向到 EC2 实例

Nginx 重定向到 EC2 实例

原来的

我有一个部署在 S3 bucket 上的 angular (版本:7) 网站,但出于 SEO 目的,最近我集成了角度通用

现在我将站点/前端从 S3 存储桶移至 EC2 实例。我正尝试在 EC2 实例 (CentOS) 上的 Nginx (版本:nginx/1.14.1) 上部署我的角度通用应用程序。

流程类似于域名(example.com/www.example.com)在 godaddy 上注册,指向 Cloud Front,它将我的请求发送/转发到 EC2 实例(Nginx 服务器)。

问题

每当我尝试访问网址时https://example.com或者https://www.example.com,他们被重定向到 EC2 实例地址,例如https://ec2-xx-xxx-xxx-xx.region-x.compute.amazonaws.com/

有人认为这是由于服务器配置造成的,如上所述这里

确保当您通过 CloudFront 连接时,服务器不会将您重定向回 EC2 主机名或 IP(如果发生这种情况,浏览器中的地址栏将会发生变化,如果发生这种情况,您将需要修复 Web 服务器的配置)。

因此,我似乎遇到了 nginx 配置问题。以下是我使用的配置。

EC2 安全组设置

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 文件。仅指向默认的 nginx 静态 html 页面(无反向代理,无花哨的配置)

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)问题。有人能告诉我解决方案吗?

相关内容