• 1847阅读
  • 1回复

504 Gateway Time-out错误的解决方法大全

楼层直达
504 Gateway Time-out错误的解决方法大全 504 Gateway Time-out就字面意思,我们可以理解为网页请求超时,也就是浏览网站网页所发出的请求没有反应或者未响应,在网站程序层面来说,就是请求未能够执行相应的PHP-CGI程序,或者PHP-CGI程序未能做出相应的处理,又或者是CGI程序的响应处理结果未能够反馈到浏览器或者未能及时反馈到浏览器。 idc`p?XP  
    I7+9~5p  
  504 Gateway Time-out错误多是存在于Nginx网站服务器环境下,多与nginx.conf与php-fpm.conf设置是否正确合理有关。504GatewayTime-out错误的解决方法就是根据网站服务器性能及网站流量等诸多因素整合考虑,正确合理的设置niginx.conf和php-fpm.conf配置。 g3n'aD@'x  
   2N#$X'8  
  进行正确合理nginx.conf配置,我们需要先了解和清楚我们网站服务器的配置性能,包括CPU、内存等,并对网站服务器进行必要的性能测试(可参考:vps主机性能测试方法详解),从而准确的掌握网站服务器自身性能状况; !"Yj|Nu6  
   |LG4=j.l  
  其次,是通过网站统计代码的添加,分析段时间内网站流量状况,比如:百度统计、CNZZ站长统计等,掌握网站日流量及PHP-CGI请求的大概情况; %m,6}yt  
   'XQ`g CF=  
  后,根据我们掌握的服务器性能状况及网络流量情况,合理的对nginx.conf中的下列字句进行合理正确的设置。 vgt]:$  
   l:;PXy6)  
  fastcgi_connect_timeout300s; ~9^)wCM+  
   W/z7"#  
  fastcgi_send_timeout300s; Z 2}ah  
    UsGa  
  fastcgi_read_timeout300s; ~I/@i  
   HD,xY4q&N  
  fastcgi_buffer_size128k; 2M<R(W!&  
   eg<bi@C1|  
  fastcgi_buffers8128k;#8128 &wd;EGGT!q  
   i"zuil  
  fastcgi_busy_buffers_size256k; Sw^X2$h  
   -aRU]kIf  
  fastcgi_temp_file_write_size256k; M7f;Pa  
   W)'*m-I  
  fastcgi_intercept_errorson; (npj_s!.C)  
   R(.}C)q3  
  这些字句的设置规定了PHP-CGI的连接、发送和读取时间限制,需根据服务器性能及网络流量综合考虑设置,时间设置过长会给网站服务器造成压力,导致网站响应缓慢,甚至服务器宕机;时间设置过短,则就会出现504 Gateway Time-out或者其他CGI无响应错误。 u&G.4QQF  
   s}5cSU!|  
  还有就是php-fpm.conf中max_children与request_terminate_timeout两个重要参数的设置。这两个参数的设置需要我们根据PHP程序情况及服务器带宽状况综合考虑并计算出合理准确的值,才能够避免504 Gateway Time-out或者其他CGI无响应错误的出现。通常情况下,般网站,可将request_terminate_timeou设置在900s左右,而max_children值根据服务器内存大小和CGI请求数目设置为合理的数值,般设置为800M左右。
只看该作者 安逸沙发  发表于: 2019-09-22
B4D#T lB  
对于一个Web开发者来说,504和502问题看上去好像很简单,每个人也可能都遇到过,但把问题说清楚并不那么容易,腾佑科技小编也希望这篇文章能够帮助您。 *?JNh;  
两台设备只要通过proxy或fastcgi协议互相通信,都会遇到504问题,比如Nginx+PHP-FPM会遇到;代理服务器连接后端Web服务也会遇到。我本次遇到的场景属于后者,重点讲解代理导致的504问题。
7J[DD5  
那到底上面是504错误呢,看下wiki的引用: wV604eO(  
4 Gateway Timeout [%0{7pz}  
The server was acting as a gateway or proxy and did not receive a timely response from the upstream server l.@v@T(/  
它的意思就是一个网关或代理服务器能够连接后端服务器,但在读取服务器响应的时候超时了。遇到504问题一般是后端服务的问题,比如: 8 t)?$j$  
后端进程无故退出了(可能是代码异常,也可能是apache或nginx进程异常),导致代理服务器接收不到后端响应。 Q)IL]S  
后端响应缓慢,导致代理服务器接收后端响应超时了。 cXd?48O  
服务器出现504 Gateway Time-out的解决方法! 8PB 8h  
按照上述可能的两个情况,逐一分析。 *el~sor;S  
(1)x.php程序在特定的情况下,确实运行缓慢,但apache的access log在25秒左右的时候成功记录了200访问日志(由于php代码执行结束后才记录日志,一开始可能看不到access日志,导致开始误认为是后端程序的问题)。 nI es}n:  
(2)在x.php程序中记录应用日志,应用日志和access log日志一样,没有任何异常。 \) FFV-k5  
这说明代码并没有问题(但程序执行时间过长,有优化的空间),虽然在20秒产生504错误(由nginx处理),后端代码进程仍然继续运行,并在25秒成功运行。 Gp9:#L!  
排除这个问题后,最有可能是代理服务器觉得后端响应过于缓慢,主动关闭了该连接,是不是代理服务器设置的超时时间过短?由于公司的代理服务器(ssl nginx)是由专人维护的,看不到具体的配置,邮件询问了同事,得到回复如下: A<U9$"j9J  
proxy_read_timeout 60 s=H| ^v  
proxy_send_timeout 60 E]0}&YG  
首先看下 proxy_read_timeout 的官方介绍: -z~;f<+I`  
Defines a timeout for reading a response from the proxied server. The timeout is set only between two successive read operations, not for the transmission of the whole response. If the proxied server does not transmit anything within this time, the connection is closed. h@{mcz  
最后将该值修改为: s L=}d[  
proxy_read_timeout 300 i",7<01  
proxy_send_timeout 300 0,]m.)ws  
问题最终解决了,肯定是proxy读取超时了,但具体的配置仍然疑惑。 Fl}{"eCF8  
进一步测试 i}gsxq%  
感兴趣的同学也可以进一步了解nginx的proxy配置,如果没有特殊的需求,配置非常简单。 V^%P}RFMc  
server { vACJE  
listen 443 ssl; ku5vaP(  
server_name www.simplehttps.com; T&nIH[}v  
location / { xl ]1TB@  
access_log access.log main; @h,3"2W{Ev  
error_log error.log;  \RS ,Y  
proxy_pass http://127.0.0.1:8080; Q#5~"C  
proxy_read_timeout 5; awl3|k/  
} 'Bwv-J  
} 2C AR2V|  
proxy_pass 可以是一个host、内部域名、ip地址,不用是一个对外的域名。 }u]7x:lh  
如果遇到超时问题,观察error.log日志,会看到以下错误: Ku?1QDhrF*  
2018/09/19 21:01:19 [error] 17034#0: *253 upstream timed out (110: Connection timed out) while reading response header from upstream, client: *.*.*.*, server: www.simplehttps.com, request: "GET /x.php HTTP/1.1", upstream: "http://*.*.*.*:8080/x.php", host: "www.simplehttps.com" slQEAqG)B  
最后经过不断调整nginx的proxy_read_timeout指令和后端x.php程序的执行时间,也没有遇到工作中遇到的问题(20秒和60秒之间不对称的问题),只能后续继续留意了。 ^Rb*mI  
腾佑小编总结 Al+}4{Q+?  
1:网关和后端的超时时间(proxy或fastcgi)必须协调一致,在本案例中,apache/mod_php运行最长时间如果是30秒,那么nginx设置的超时时间必须大于30秒,因为必须考虑网络传输延时时间(非网络包总传输时间);而如果是nginx+php-fpm模式,nginx设置的超时时间相对简单,因为大部分情况下,nginx和php-fpm部署在同一台机器上,网络延时相对较短,但必须考虑php最大执行时间和php-fpm最大执行时间, ^#!\VGnL  
2:针对5**错误,可认为都是http错误码,都是服务器端的错误(相对于客户端),在遇到相关错误的时候,我们必须根据错误码判断可能存在的问题,然后再针对性的排查,否则排查时间会增加很多。
快速回复

限100 字节
安逸网提示:如果您在写长篇帖子又不马上发表,建议存为草稿
 
认证码:
上一个 下一个