ben
ben

Reputation: 1525

nginx 504 Gateway Time-out

I'm running a rails3.0.7 project with phusion-passenger on nginx. While I was doing a ajax which took about 15 mins to process. It jump up an error with firebug which said "504 Gateway Time-out" after 10 mins from calling the ajax.

Could someon give me some idea of how I could find the problem.

Thanks, ben

environment

Upvotes: 10

Views: 34360

Answers (4)

Lalit Kumar Maurya
Lalit Kumar Maurya

Reputation: 5565

I had the similar issue with Rails 4 on Mac OS X (Yosemite). So I have added the below into my specific Nginx location.

proxy_connect_timeout 43200000;
proxy_read_timeout    43200000;
proxy_send_timeout    43200000;

So my overall configuration for Nginx as below.

location /my_sub_path/ {
    root /my/rails/project/public/folder/path

    proxy_http_version 1.1;
    chunked_transfer_encoding off;
    proxy_buffering off;
    proxy_cache off;

    proxy_connect_timeout 43200000;
    proxy_read_timeout    43200000;
    proxy_send_timeout    43200000;

    proxy_redirect     off;
    proxy_set_header   Host             $http_host;
    proxy_set_header   X-Real-IP        $remote_addr;
    proxy_set_header   X-Forwarded-Proto $scheme;
    proxy_pass http://127.0.0.1:3000/;
}

Upvotes: 5

sir
sir

Reputation: 1

It's a problem from phusion-passenger. You should alter the file:(gems > passenger-3.0.18 > ext > nginx > Configuration.c)

ngx_conf_merge_msec_value(conf->upstream_config.send_timeout,
                          prev->upstream_config.send_timeout, 6000000);

ngx_conf_merge_msec_value(conf->upstream_config.read_timeout,
                          prev->upstream_config.read_timeout, 6000000);

The origin timeout is 600000, just 10 minutes. I've tried to change the nginx.conf, but didn't work.

Upvotes: -1

Shankar Banjara
Shankar Banjara

Reputation: 1

That's an nginx timeout error.

Upvotes: -6

Glenn Snyder
Glenn Snyder

Reputation: 1768

That's an nginx timeout error. Look at the following article for some clues as to which parameter you need to adjust to avoid the timeout, if you really want to allow more than 10 minutes to complete the task.

How do I prevent a gateway timeout with nginx

Upvotes: 7

Related Questions