ERR_TOO_MANY_REDIRECTS Rails + Puma + Nginx(Dockerized)

daolsyd0  于 2023-10-17  发布在  Nginx
关注(0)|答案(1)|浏览(140)

我正在使用puma和nginx运行一个dockerized rails应用程序,但是,当我试图从浏览器访问应用程序时,我会得到ERR_TOO_MANY_REDIRECTS。我在我的application.rb上有config.force_ssl = true,这是我的nginx conf文件:

upstream kisoul {
  server rails:3000;
}

server {
  listen 80;
  listen 443 ssl;
  root /usr/share/nginx/kisoul;

  try_files $uri @kisoul;

  location @kisoul {
    proxy_pass_request_headers on;
    proxy_ignore_headers       Expires Cache-Control;
    proxy_set_header           Host $http_host;
    proxy_pass_header          Set-Cookie;
    proxy_set_header           X-Forwarded-Proto https;
    proxy_pass                 http://kisoul;
  }

  ssl_certificate      /etc/nginx/fullchain.pem;
  ssl_certificate_key  /etc/nginx/privkey.pem;
}

我已经试过从rails禁用force_ssl并强制通过nginx重定向,但后来我遇到了Origin头的问题,说origin头(https://localhost)不匹配request.base_url(HTTP://localhost)
我尝试了许多不同的解决方案已经在这里描述,但我找不到任何解决方案

olhwl3o2

olhwl3o21#

下面的一行,在你的NGINX配置中,应该在你的Ruby on Rails应用程序中修复config.force_ssl = true时修复ERR_TOO_MANY_REDIRECTS

proxy_set_header X-Forwarded-Proto https;

看看我最近做的/etc/nginx/sites-available/default,rails + puma + nginx + let's encrypt:

upstream app {
  server unix:/var/www/mydomain/tmp/puma.sock;
}

server {
  server_name mydomain.com www.mydomain.com;

  root /var/www/mydomain/public;
  access_log /var/www/mydomain/log/nginx.access.log;
  error_log /var/www/mydomain/log/nginx.error.log;

  location ^~ /assets/ {
    gzip_static on;
    expires max;
    add_header Cache-Control public;
  }

  try_files $uri/index.html $uri @app;
  location @app {
    proxy_set_header X-Forwarded-Proto https;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header Host $http_host;
    proxy_redirect off;

    proxy_pass http://app;
  }

  error_page 500 502 503 504 /500.html;
  client_max_body_size 10M;
  keepalive_timeout 10;

  listen 443 ssl; # managed by Certbot
  ssl_certificate /etc/letsencrypt/live/mydomain.com/fullchain.pem; # managed by Certbot
  ssl_certificate_key /etc/letsencrypt/live/mydomain.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
}

相关问题