Nginx 504 Gateway Time-out

1、场景:
因业务需求写了一个比较耗时的脚本,在命令行中脱离nginx可以正常执行,但用浏览器执行用nginx做反向代理就出现
“504 Gateway Time-out”;
2、分析:
Nginx 504 Gateway Time-out的含义是所请求的网关没有请求到,简单来说就是没有请求到可以执行的PHP-CGI
通常以下几种情况会导致这个问题:
1.程序在处理大量的数据,或者有死循环之类的问题
2.创建数据库之类的连接因为某些原因连接不上,然后没有超时失败的机制,导致一直在创建连接
3.程序中有一些http请求,这些请求执行时间过长,导致超时
3、解决:
在nginx配置文件中server里面的location ~ \.php(.*)$ {中增加如下代码:

fastcgi_connect_timeout 1200s; #原设置为300s fastcgi_send_timeout 1200s; #原设置为300s fastcgi_read_timeout 1200s; #原设置为300s fastcgi_buffers8 128K; fastcgi_buffer_size128;

4、原因:
【Nginx 504 Gateway Time-out】nginx配置项:
fastcgi_connect_timeout #同 FastCGI 服务器的连接超时时间,默认值60秒,它不能超过75秒; fastcgi_send_timeout #Nginx 进程向 FastCGI 进程发送 request ,整个过程的超时时间,默认值60秒; fastcgi_read_timeout #FastCGI进程向Nginx进程发送 response ,整个过程的超时时间,默认值60秒;

php配置项:
php.ini max_execution_time = 300s; PHP 脚本的最大执行时间,但是,在 php-cgi(php-fpm) 中,该参数不会起效。 php-fpm request_terminate_timeout = 0; #设置单个请求的超时中止时间.设置为0 即一直执行下去直到程序结束 不会超时


此时,没有出现nginx502,解决!

    推荐阅读