502 неверная ошибка шлюза (nginx + unicorn + digital ocean)

Я несколько часов пытался решить эту проблему, но все равно это не работает. Ошибка, которую я вижу в своем браузере:

POST /users 502 (неверный шлюз)

Знаю, что проблема в настройке nginx и unicorn, но решить не могу. Кстати, я развернул свой код с помощью цифрового океана. Вот мой файл конфигурации


Конфиг единорога (nginx.conf):

 user              nginx;
 worker_processes  1;
 error_log  /var/log/nginx/error.log;
 pid        /var/run/nginx.pid;
 events {
  worker_connections  1024;
 }
 http {
   server_names_hash_bucket_size 64;
   include       /etc/nginx/mime.types;
   default_type  application/octet-stream;

   log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                  '$status $body_bytes_sent "$http_referer" '
                  '"$http_user_agent" "$http_x_forwarded_for"';

   access_log  /var/log/nginx/access.log  main;

   sendfile        on;
   #tcp_nopush     on;

   #keepalive_timeout  0;
   keepalive_timeout  65;

   #gzip  on;

   # Load config files from the /etc/nginx/conf.d directory
   # The default server is in conf.d/default.conf
   include /etc/nginx/conf.d/*.conf;
   fastcgi_buffers 8 16k;
   fastcgi_buffer_size 32k;
   fastcgi_connect_timeout 300;
   fastcgi_send_timeout 300;
   fastcgi_read_timeout 300;
}

Файл конфигурации единорога (/var/nginx/unicorn.conf):

upstream unicorn {
  server unix:/tmp/unicorn.sock fail_timeout=0;
}

server {

  listen              80;
  listen              443 ssl;
  ssl_certificate     /root/certs/server.crt;
  ssl_certificate_key /root/certs/server.key;

  client_max_body_size 4G;
  keepalive_timeout 15;
  root /var/www/quoine/current/public;
  try_files $uri @unicorn;

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

  location = /app/ {
    rewrite $uri $uri/index.html;
  }

  location = /app/index.html {
    add_header Pragma "no-cache";
    add_header Cache-Control "no-cache, no-store, max-age=0, must-revalidate";
    add_header Expires "Fri, 01 Jan 1990 00:00:00 GMT";
  }

  location @unicorn {
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header Host $http_host;
    proxy_set_header X-Forwarded-Proto $scheme;
    proxy_redirect off;
    proxy_pass http://unicorn;
  }

  if (-f $document_root/system/maintenance.html) {
    return 503;
  }

  error_page 500 502 504 /500.html;
  location = /500.html {
    root /var/www/quoine/current/public;
  }

  error_page 503 @maintenance;
  location @maintenance {
    rewrite  ^(.*)$  /system/maintenance.html break;
  }
}

Я использую Rails 3. Если кто-нибудь знает об этой проблеме, сообщите мне. У меня уходит 3 часа без какого-либо прогресса. Спасибо


person le duc quang    schedule 24.10.2014    source источник
comment
Что говорит ошибка в лог-файлах?   -  person Danack    schedule 24.10.2014


Ответы (2)


Можете ли вы также предоставить конфигурацию, которую вы получили для единорога (предоставленные вами файлы предназначены для nginx). Пример того, как это должно выглядеть, приведен в первой части записи «Настройка серверов» здесь: https://www.digitalocean.com/community/tutorials/how-to-deploy-rails-apps.-using-unicorn-and-nginx-on-centos-6-5

person Glenn Gillen    schedule 26.10.2014

Я столкнулся с этим, пытаясь понять, почему я получаю 502 ошибки после использования установки Digital Ocean в один клик и другой версии Ruby.

Я нашел ответ, просмотрев это руководство: https://www.digitalocean.com/community/tutorials/how-to-use-the-1-click-ruby-on-rails-on-ubuntu-14-04-image

Моя проблема заключалась в следующем из руководства:

После того, как у вас есть местоположение Ruby, которое вы используете по умолчанию, измените пути /etc/default/unicorn, чтобы включить подпапку /usr/local/rvm/rubies и подпапки /usr/local/rvm/gems для вновь установленной версии. как местонахождение единорога

Надеюсь, это поможет кому-то

person Ryan Drost    schedule 04.04.2015