报错信息

504 Gateway Time-out
原因是程序执行时间过长,导致请求超时。
504 Gateway Time-out

问题分析

nginx访问出现504 Gateway Time-out,一般是由于程序执行时间过长导致响应超时,例如程序需要执行90秒,而nginx最大响应等待时间为30秒,这样就会出现超时。

通常有以下几种情况导致

  1. 程序在处理大量数据,导致等待超时。 
  2. 程序中调用外部请求,而外部请求响应超时。 
  3. 连接数据库失败而没有停止,死循环重新连。

出现这种情况,我们可以先优化程序,缩短执行时间。另一方面,可以调大nginx超时限制的参数,使程序可以正常执行。

对于访问超时的设定,nginx与php都有相关的设置,可以逐一进行修改。

解决办法

修改nginx.conf配置文件

1
2
3
4
5
6
7
8
keepalive_timeout  600;#原设置为300s
fastcgi_connect_timeout 600;#原设置为300s
fastcgi_send_timeout 600;#原设置为300s
fastcgi_read_timeout 600;#原设置为300s
proxy_connect_timeout 600;#原设置为300s
proxy_send_timeout 600;#原设置为300s
proxy_read_timeout 600;#原设置为300s
send_timeout 600;#原设置为300s

修改完成后,使用nginx -t命令看下配置文件是否正常,最后再使用nginx -s reload重启nginx服务即可。