• 1755阅读
  • 0回复

nginx 504 Gateway Time-out错误解决方法

楼层直达
一般看来, 这种情况可能是由于nginx默认的fastcgi进程响应的缓冲区太小造成的, 这将导致fastcgi进程被挂起, 如果你的fastcgi服务对这个挂起处理的不好, 那么最后就极有可能导致504 Gateway Time-out ddG5g  
现在的网站, 尤其某些论坛有大量的回复和很多内容的, 一个页面甚至有几百K XR.Sm<A[  
默认的fastcgi进程响应的缓冲区是8K, 我们可以设置大点 qe_59'K  
v*VId l>  
在nginx.conf里, 加入: _{f7e^;  
HVkq{W|w  
fastcgi_buffers 8 128k SRBQ"X[M2  
G'0]m-)dw  
这表示设置fastcgi缓冲区为8×128k 2/M:KR  
当然如果您在进行某一项即时的操作, 可能需要nginx的超时参数调大点, 例如设置成60秒: M<VZISu)dy  
})^%>yLfc|  
send_timeout 60; cO^}A(Ma(  
1KWGQJ%%s  
我只是调整了这两个参数, 结果就是没有再显示那个超时, 可以说效果不错 ,)](h+zl_6  
/By`FW Y  
另一篇文章 d-BUdIz  
B`1"4[{  
首先是更改php-fpm的几处配置: pR*)\@ma  
s%p,cz; ,  
把max_children由之前的10改为现在的30,这样就可以保证 有充足的php-cgi进程可以被使用; .6xIg+  
p?qW;1  
把request_terminate_timeout由之前的0s改为60s,这样php-cgi进程 处理脚本的超时时间就是60秒,可以防止进程都被挂起,提高利用效率。 [23F0-p  
l S m7i  
接着再更改nginx的几个配置项,减少FastCGI的请求次 数,尽量维持buffers不变: Y]-7T-*+t  
\yNe5  
fastcgi_buffers由 4 64k 改为 2 256k; ->29Tns  
fastcgi_buffer_size 由 64k 改为 128K; k),!%6\(  
fastcgi_busy_buffers_size 由 128K 改为 256K; HJ+I;OJ  
fastcgi_temp_file_write_size 由 128K 改为 256K。 ~|t 7  
JZM:R  
好了,重新加载php-fpm和nginx的配置,再次测试,至今两周时间内没有再出现504 Gateway Time-out的情况,算是达到效果了。 5o P 3 1  
>nA6w$  
另外,php-fpm的默认静态处理方式会使得php-cgi的进程长期占用内存而无法释放,这也是导致nginx出错的原因之一,因此可以将php-fpm的处理方式改成apache模式。 ;[}<xw3):  
apache-like u(92y]3,  
快速回复

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