WDlinux官方论坛's Archiver

zhutou5 发表于 2012-5-20 06:04

解决nginx 504 Gateway Time-out的一些方法

[align=left]
[b]在CentOS下配置lnmp组合基本上用的都是同样的配置文件,一直都没出现过问题,可最近在一个vps上安装同样的环境之后,网站在线10多人就出 现了打开速度非常缓慢的情况,有好几次都是直接达到了nginx中设置的脚本最大超时时间300秒,结果导致nginx往客户端浏览器发送了一个504 Gateway Time-out的错误代码,分析了之后改动了几处配置文件,终于避免了该情况的出现。
  [/b]
  从 错误代码基本可以确定跟nginx本身无关,主要是提交给php-fpm的请求未能正确反馈而导致,一般情况下,提交动态请求的时候,nginx会直接把 请求转交给php-fpm,而php-fpm再分配php-cgi进程来处理相关的请求,之后再依次返回,最后由nginx把结果反馈给客户端浏览器,但 我这个vps目前跑的是个纯php应用内容,实际上用户所有的请求都是php请求,有的耗费时间比较久,php-cgi进程就一直都被用满,而php- fpm本身的配置文件只打开了10组php-cgi进程,这样的话在线用户稍微多的话就会导致请求无法被正常处理而出错。
  
  大概分析出了原 因,下面做就比较容易了,首先是更改php-fpm的几处配置:
  
  把max_children由之前的10改为现在的30,这样就可以保证 有充足的php-cgi进程可以被使用;
  把request_terminate_timeout由之前的0s改为60s,这样php-cgi进程 处理脚本的超时时间就是60秒,可以防止进程都被挂起,提高利用效率。
  
  [b]接着再更改nginx的几个配置项,减少FastCGI的请求次 数,尽量维持buffers不变:
  [/b]
  fastcgi_buffers由 4 64k 改为 2 256k;
  fastcgi_buffer_size 由 64k 改为 128K;
  fastcgi_busy_buffers_size 由 128K 改为 256K;
  fastcgi_temp_file_write_size 由 128K 改为 256K。
  
  好了,重新加载php-fpm和nginx的配置,再次测试,至今两周时间内没有再出现504 Gateway Time-out的情况,算是达到效果了。

  另外,php-fpm的默认静态处理方式会使得php-cgi的进程长期占用内存而无法释放,这也是导致nginx出错的原因之一,因此可以将php-fpm的处理方式改成apache模式。
  <value name=”style”>apache-like</value>
  [b]从更改完毕到现在的测试表明上述方式的效果还是很明显的,并没有发现一次Nginx502 bad gateway或504 Gateway Time-out错误。当然,如果你的VPS或者服务器的性能足够好可以根据具体情况不必做无谓的改动。[/b][/align]

zhutou5 发表于 2012-5-20 06:08

[i=s] 本帖最后由 zhutou5 于 2012-5-20 06:09 编辑 [/i]

LNMP的朋友试试这个 (以512内存的vps为例)
1.调整php-fpm.conf的相关设置/www/wdlinux/etc/:
<value name=”max_children”>32</value>
<value name=”request_terminate_timeout”>30s</value>

22.调整nginx.conf的相关设置/www/wdlinux/nginx-1.0.12/conf:
fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 256k;

zhutou5 发表于 2012-5-20 06:11

对了修改了这些参数,内存消耗有所增加。如果不能接受的,建议不要修改

yanhailou 发表于 2012-6-19 09:28

nginx.conf 文件里没有
22.调整nginx.conf的相关设置/www/wdlinux/nginx-1.0.12/conf:
fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 256k;

这些参数呢

zhutou5 发表于 2012-6-27 00:12

[b]回复 [url=http://www.wdlinux.cn/bbs/redirect.php?goto=findpost&pid=8581&ptid=2194]4#[/url] [i]yanhailou[/i] [/b]


    直接在里面添加即可

云飞 发表于 2013-12-15 18:22

[i=s] 本帖最后由 云飞 于 2013-12-15 18:25 编辑 [/i]

按你这个设置了,重启服务 器后在DZ后台 群发短消息还是504错误,把发送量改为20后正常发送了。

ibq00 发表于 2013-12-16 21:42

留一个脚印!谢谢大哥!:lol

0215 发表于 2014-2-28 14:48

请问php-fpm在那个目录?

0215 发表于 2014-2-28 15:01

fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 256k;


请问以上添加在该文件什么位置?我加在最后,但是出错。。。

joexiaoh 发表于 2014-3-2 15:01

呵呵不错哦      收藏了

注册啊 发表于 2014-8-6 15:38

[b]回复 [url=http://www.wdlinux.cn/bbs/redirect.php?goto=findpost&pid=7475&ptid=2194]2#[/url] [i]zhutou5[/i] [/b]


   谢谢,改了还是依然存在,

两天 发表于 2015-3-19 07:49

fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 256k;


请问以上添加在该文件什么位置?

yuedang 发表于 2016-7-3 12:10

对啊,网上找了那么多,都没有一个完整的。气死了

hanzs 发表于 2016-8-23 15:29

请问502如何解决

cbin 发表于 2016-12-5 14:25

这种事,还是不要随便改。。。最讨厌教程说一段的。。。

y072154750 发表于 2018-8-22 10:31

[b]回复 [url=http://www.wdlinux.cn/bbs/redirect.php?goto=findpost&pid=94066&ptid=2194]15#[/url] [i]cbin[/i] [/b]


   https://www.cnblogs.com/sbfnxk201/p/6183920.html这个完整点

810007939 发表于 2021-11-6 02:07

对啊,网上找了那么多,都没有一个完整的。气死了

页: [1]

Powered by Discuz! Archiver 7.2  © 2001-2009 Comsenz Inc.