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_buffers      8 128K;
 fastcgi_buffer_size  128;

4、原因:

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,解决!

 

你可能感兴趣的:(nginx)