Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

502 Bad Gateway when using ExpressJS with nginx

If I run my expressjs app like so: coffee server.coffee and navigate to localhost:8080, everything works just fine.

However, when I reverse proxy 8080 with nginx with the following configuration:

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;
}

I get the following error in the Chrome Dev console:

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

and the following in nginx's 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/"

Any guidance appreciated!

like image 666
Mark Avatar asked Mar 21 '11 23:03

Mark


People also ask

Why do I get 502 bad gateway message?

A 502 bad gateway message indicates that one server got an invalid response from another. In essence, you've connected with some kind of interim device (like an edge server) that should fetch all of the bits you need to load the page. Something about that process went wrong, and the message indicates the problem.


2 Answers

I am new to setting up a VMS using nginx and forever with nodejs/meanjs. My goal was to configure a proxy to be able to serve my app on the default port 80 rather than from port 3000.

While fumbling about with nginx server block snippets from a variety of different online examples I started to hit a wall with "502 Bad Gateway" errors. Through a lot of trial and error I was finally able to resolve this condition.

In the end, what seemed like equivalent ways of using forever to start node ended up with very different results.

What results in 502 Bad Gateway:

When issued from the server's root using an absolute path to the node script, this command failed with a 502:

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

Actually, for that matter if node is not running at all I was also getting a 502 error.

What works:

Two ways that did work were either starting forever from my project's root directory without specifying a path to the node script (just the filename) or again from the server's root but using the sourceDir option:

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

Or:

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

Just for completeness I will also include the nginx server block in case that helps provide some additional context:

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;
        }
}
like image 132
darrendb Avatar answered Sep 26 '22 22:09

darrendb


Try this patch...

    -proxy_pass http://node/;
    +proxy_pass http://node;
like image 33
CyberDem0n Avatar answered Sep 25 '22 22:09

CyberDem0n