502 Bad Gateway при использовании ExpressJS с nginx - PullRequest
9 голосов
/ 22 марта 2011

Если я запускаю свое приложение expressjs следующим образом: coffee server.coffee и перехожу на localhost:8080, все работает просто отлично.

Однако, когда я возвращаю прокси-сервер 8080 с помощью nginx со следующей конфигурацией:

server {
    listen 0.0.0.0:80;
    server_name localhost;
    access_log /var/log/nginx/nodetest.log;

    location / {
      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_set_header X-NginX-Proxy true;

      proxy_pass http://node/;
      proxy_redirect off;
    }
}

upstream node {
    server 127.0.0.1:8080;
}

В консоли Chrome Dev появляется следующая ошибка:

GET http://184.73.217.204/socket.io/xhr-polling//1300750540040 502 (Bad Gateway)

и следующие в nginx error.log

2011/03/22 13:07:59 [error] 10269#0: *18 upstream prematurely closed connection while
reading response header from upstream, client: 168.229.58.68, server: localhost, 
request:     "GET /socket.io/xhr-polling//1300799281533 HTTP/1.1", upstream:     
"http://127.0.0.1:8080/socket.io/xhr-polling/1300799281533", host: "184.73.217.204",    
referrer: "http://184.73.217.204/"

Любое руководство приветствуется!

Ответы [ 2 ]

23 голосов
/ 22 марта 2011

Попробуйте этот патч ...

    -proxy_pass http://node/;
    +proxy_pass http://node;
1 голос
/ 18 ноября 2014

Я новичок в настройке VMS с использованием nginx и forever с nodejs / meanjs.Моя цель состояла в том, чтобы настроить прокси-сервер так, чтобы он мог обслуживать мое приложение на порте 80 по умолчанию, а не на порте 3000.

Пока возился с фрагментами блоков сервера nginx из множества разных онлайн-примеров, я начал поражатьстена с ошибками "502 Bad Gateway".Через много проб и ошибок я наконец смог решить это условие.

В конце концов, то, что казалось эквивалентными способами использования forever для запуска node, привело к совершенно другим результатам.

Что приводит к ошибке 502 Bad Gateway:

При выдаче из корня сервера с использованием абсолютного пути к сценарию узла эта команда завершилась неудачно с 502:

$ cd /
$ sudo forever start --spinSleepTime 10000 /var/www/mydomain.com/server.js

На самом деле, в этом случае, если node вообще не работает, я также получаю ошибку 502.

Что работает:

Два способа, которые работали, либо запускали forever с моегокорневой каталог проекта без указания пути к скрипту узла (только имя файла) или снова из корневого каталога сервера, но с использованием параметра sourceDir:

$ cd /var/www/mydomain.com
$ sudo forever start --spinSleepTime 10000 server.js

или:

$ cd /
$ sudo forever start --spinSleepTime 10000 --sourceDir /var/www/shotplot.info/ server.js

Просто для полноты я также включу блок сервера nginx на случай, если это поможет обеспечить некоторый дополнительный контекст:

upstream nodejs \{
        server 127.0.0.1:3000;
}
server {
        root /var/www/mydomain.com;
        server_name mydomain.com www.mydomain.com;

        location / {
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $remote_addr;
                proxy_set_header Host $host;
                proxy_pass http://nodejs;
                proxy_redirect off;
        }
}
...