• 479阅读
  • 1回复

504 Gateway time-out错误的解决方法

楼层直达
Nginx的特点是处理静态很给力,Apache的特点是处理动态很稳定,两者结合起来便是LNMPA,nginx处理前端,apache处理后端,这样处理静态会很快,处理动态会很稳定。当我以为安装完成以后便万事大吉,不料更新网站的时候却出现504 Gateway time-out;起初还以为这是偶然,多次尝试后依然出现这样的情况,因此才决定查找解决方法。 `T"rG }c  
_BS 9GB  
  LNMP面对504 Gateway time-out | o0RP|l  
81F,Y)x.  
  因为504 Gateway time-out是Nginx的专属错误,因此起初我以为是nginx配置出错,查找网上的教程,找到相应的解决方法,下面简单说说LNMP面对此种情况的解决方案。Nginx出现这样的错误,是因为对PHP-CGI进程数限制得太小,面对更新网站这类操作,很可能出现进程不足而超时的情况,因此要修改两处涉及到处理时间的文件。 6|!NLwa  
_1|$P|$P.  
  首先是nginx.conf文件,这个文件在/www/wdlinux/nginx/conf/nginx.conf,打开以后,主要修改前面几个时间,建议修改为120秒以上。至于用什么工具修改,推荐在线命令行编辑;或者用winscp下载下来,用Dreamweaver修改。 K2rzhHfb  
"DQ'C%sL9  
/www/wdlinux/nginx/conf/nginx.conf 和 /www/wdlinux/nginx-1.0.15/conf/nginx.conf是一样的。 OeElMRU"  
  fastcgi_connect_timeout 300s; i  sW\MB]  
*Zbuq8>  
  fastcgi_send_timeout 300s; OBOwz4<  
E0l _--  
  fastcgi_read_timeout 300s; :243H  
mfom=-q3k  
  fastcgi_buffer_size 128k; H&4~Uo.5  
x83a!9  
  fastcgi_buffers 8 128k;#8 128 ,^$ |R32  
 ?=Db@97  
  fastcgi_busy_buffers_size 256k; qlsQ|/'D  
U BZ9A  
  fastcgi_temp_file_write_size 256k; qpp/8M  
md bp8,O  
  其次要修改php-fpm.conf文件,这个文件在/www/wdlinux/etc/php-fpm.conf,不同的一键安装包位置有所不同,反正找找php安装以后文件下面的etc文件夹即可,在线编辑或下载下来用Dreamweaver编辑。 +dW|^I{H}  
\9{F5S z  
  进入文件后搜索”max_children”这是php-cgi进程数,一个进程占20M~30M内存,按自己的VPS或云主机内存进行计算,好比512M内存,推荐设置为18即可;另外搜索”request_terminate_timeout”,这是超时时间,若php程序要长时间运作,那么设置时间大一点会比较好,好比设置为120秒,单位默认是秒,或者写成120同样可以。 T!2=*~A  
D'_Bz8H!p  
  LNMPA遇到504 Gateway time-out y\c"b-lQX  
xJwG=$o  
  当我按照Nginx的解决方法设置,很快设置成功,不过依然会出现504 Gateway time-out,这时我直接切换为LNMP组合,发现不再遇到504 Gateway time-out错误,这说明设置已经生效;为什么还会出现这样的错误呢? 6^)}PX= *  
v;EQ, NL  
  经过大量的资料查找,终于发现这是Nginx与Apache通信时间设置问题,当用户发出php脚本执行请求,nginx不会执行php,会把这个问题留给后台的apache,nginx会等待一段时间,apache可以在等待时间内处理php脚本请求,若未处理完,nginx便已未收到数据请求而返回504 Gateway time-out错误,实际情况是apache依然会在后台处理完php脚本,只是前台返回错误。 BR5BJX  
1X1 N tS @  
  解决方法是修改nginx与apche通信时间,具体是配置naproxy.conf,这个文件在/www/wdlinux/nginx/conf/下面,名字可能会有变化,好比有的安装包是naproxy.conf,反正是**proxy.conf文件。 {~Tg7<\L  
Vb|#MNf)  
  proxy_connect_timeout 60; C$yq\C+I  
JXqr3 Np1  
  proxy_send_timeout 600; Shr,#wwM`B  
!Ng=Yk>3  
  proxy_read_timeout 90; w#y0atsg'  
iw9Q18:I}  
  proxy_buffer_size 128k; MGpt}|t-  
^K(^I*q  
  proxy_buffers 8 128k; Nw_@A8-r  
RFaSwf,5n  
  proxy_busy_buffers_size 256k; 1bnBji  
BUZ _)  
  proxy_temp_file_write_size 100m; 0&+k.Vg  
K2)!h.W  
  第一项是连接时间,前端连接后端时间,60s以内即可,第二个是发送时间,允许后端返回数据的时间,90s以内即可,第三个时间是读写时间,这是前端等待后端处理时间,这是导致504 Gateway time-out的根本原因,出现这个错误,说明这个值太小,推荐不小于600s,服务器越差,那么设置得更长,保证处理完毕。 ?~e3 &ux  
O[^%{'  
  当我把这个文件设置好,重启nginx和apache,再次更新文章,已经不会遇到这类错误,说明出错原因不是nginx,而是前段和后端的通信时间太短。另外,nginx还会有502错误,实际上原理是差不多的,同样设置上面这部分文件,LNMPA组合依然是设置前后端的通信时间。
 
只看该作者 安逸沙发  发表于: 2019-01-05
今天程序在执行一项excel导出任务的时候 出现了nginx超时的提示 wXIRn?z  
$Zu?Gd?  
nginx 504 Gateway Time-out YzESV Th  
UxGu1a  
排查过程: .nPOjwEx&Y  
`HX:U3/  
查看该任务 发现内容是一个数据量20000条信息 每条信息有50个字段 在执行导出为excel的时候 出现了该问题 rfqwxr45h  
P([!psgu  
执行时间大概在10分钟左右就出现超时 W_W!v&@E=  
2][9Wp  
分析: 8ymdg\I+L  
W'C>Fn}lO?  
Nginx 504 Gateway Time-out的含义是所请求的网关没有请求到,简单来说就是没有请求到可以执行的PHP-CGI y98FEG#S}  
通常以下几种情况会导致这个问题: ]l,D,d81  
1.程序在处理大量的数据,或者有死循环之类的问题 z@,pT"rb  
2.创建数据库之类的连接因为某些原因连接不上,然后没有超时失败的机制,导致一直在创建连接 |p:4s"NT  
3.程序中有一些http请求,这些请求执行时间过长,导致超时 S2$66xr#  
v \:AOY'  
分别查看nginx及php的相关配置查看timeout具体参数 ~<[+!&<U  
t]h_w7!U  
找到nginx配置文件 t\M6 d6  
H8eEBMGo  
复制代码 ~ P\4 N  
#修改Nginx配置: 4|?(LHBD)  
fastcgi_connect_timeout 1200s;#原设置为300s Gdow[x  
fastcgi_send_timeout 1200s;#原设置为300s hIV9.{J  
fastcgi_read_timeout 1200s;#原设置为300s A%^?z.  
fastcgi_buffer_size 64k; dcf,a<K\  
fastcgi_buffers 4 64k; B ~v6_x  
fastcgi_busy_buffers_size 128k; :Qa*-)rs  
fastcgi_temp_file_write_size 256k; 1S?~ c25=h  
复制代码 m6i ,xn  
这里最主要的设置是前三条,即 .#&)%}GC  
V D#q\  
fastcgi_connect_timeout #同 FastCGI 服务器的连接超时时间,默认值60秒,它不能超过75秒; #(tdJ<HvC|  
fastcgi_send_timeout #Nginx 进程向 FastCGI 进程发送 request ,整个过程的超时时间,默认值60秒; -HF?1c  
fastcgi_read_timeout #FastCGI  进程向  Nginx  进程发送 response ,整个过程的超时时间,默认值60秒; TzKM~a#  
php配置文件 E-WpsNJ)X  
1K/HVj+'.  
php.ini WOO3z5 La  
max_execution_time = 300s;PHP 脚本的最大执行时间,但是,在 php-cgi(php-fpm) 中,该参数不会起效。 Fg`<uW]TFZ  
php-fpm rZgu`5 <a  
request_terminate_timeout = 0; #设置单个请求的超时中止时间.设置为0 即一直执行下去直到程序结束 不会超时 ew\:&"@2]w  
修改完上述设置之后 再次执行发现没有出现504超时提示,但是页面空白,并没有文件导出。应该还是php在执行过程中超时 KpGx<+0p  
o(tJc}Mh+(  
没办法 查看php代码并没有发现有执行时间的设置即:set_time_limit }XUL\6U  
QvbH " 7  
百度一下php函数执行时间 查到以下内容: k~ )CJ6}  
ozY$}|sjDT  
set_time_limit F > rr.  
Tf#Op v)  
本函数用来配置该页最久执行时间。默认值是 30 秒,在 php.ini 中的 max_execution_time 变量配置,若配置为 0 则不限定最久时间。 uihH")Mo  
7)U ik}0  
当执行到该函数时,才开始计算。例如,若默认是 30 秒,而在执行到该函数前已执行了 25 秒,而用本函数改为 20 秒,则该页面最长执行时间为 45 秒。 @;O"-7Kk  
N_92,xI#  
最后在php函数里 添加了这样一行: ICz:>4M-dn  
fgqCX:SWz  
set_time_limit(0); .c>6}:ye  
@tSB^&jUWu  
再次执行,结果可以了。
快速回复

限100 字节
安逸网提示:如果您提交过一次失败了,可以用”恢复数据”来恢复帖子内容
 
认证码:
上一个 下一个