nginx 504 Gateway Time-out错误解决方法
一般看来,这种情况可能是由于nginx默认的fastcgi进程响应的缓冲区太小造成的,这将导致fastcgi进程被挂起,如果你的fastcgi服务对这个挂起处理的不好,那么最后就极有可能导致504GatewayTime-out
现在的网站,尤其某些论坛有大量的回复和很多内容的,一个页面甚至有几百K
默认的fastcgi进程响应的缓冲区是8K,我们可以设置大点
在nginx.conf里,加入:
fastcgi_buffers8128k
这表示设置fastcgi缓冲区为8×128k
当然如果您在进行某一项即时的操作,可能需要nginx的超时参数调大点,例如设置成60秒:
send_timeout60;
我只是调整了这两个参数,结果就是没有再显示那个超时,可以说效果不错
另一篇文章
首先是更改php-fpm的几处配置:
把max_children由之前的10改为现在的30,这样就可以保证有充足的php-cgi进程可以被使用;
把request_terminate_timeout由之前的0s改为60s,这样php-cgi进程处理脚本的超时时间就是60秒,可以防止进程都被挂起,提高利用效率。
接着再更改nginx的几个配置项,减少FastCGI的请求次数,尽量维持buffers不变:
fastcgi_buffers由464k改为2256k;
fastcgi_buffer_size由64k改为128K;
fastcgi_busy_buffers_size由128K改为256K;
fastcgi_temp_file_write_size由128K改为256K。
好了,重新加载php-fpm和nginx的配置,再次测试,至今两周时间内没有再出现504GatewayTime-out的情况,算是达到效果了。
另外,php-fpm的默认静态处理方式会使得php-cgi的进程长期占用内存而无法释放,这也是导致nginx出错的原因之一,因此可以将php-fpm的处理方式改成apache模式。
apache-like