当前位置: 首页 > 知识 >正文

解决 502、504 Gateway Time-out(nginx)

504网关超时问题在使用nginx作为web服务器的服务器的网站中很常见。

我在升级discuz论坛的时候遇到了这个问题。

一般来说,这种情况可能是由于nginx默认fastcgi进程响应的缓冲区太小,会导致fastcgi进程挂起。如果您的fastcgi服务没有很好地处理这种暂停,很可能会导致504网关超时。

现在的网站,尤其是一些论坛,回复很多,内容很多,一个页面甚至有几百k。

默认的fastcgi进程响应缓冲区是8K,因此我们可以将其设置得更大。

在nginx.conf中,添加:

fastcgi_buffers 8 128k

这意味着将fastcgi缓冲区设置为8128k。

当然,如果您正在进行即时操作,您可能需要增加nginx的超时参数,例如,增加到60秒:

send_timeout 60;

我只是调整了这两个参数,结果是超时不显示。可以说效果不错,但也可能是因为其他原因。目前关于nginx的资料并不多,很多东西需要长期的体验才能得到结果。期待你的发现!

Nginx 502 Bad Gateway是指请求的php-CGI已经执行,但是由于某种原因(通常是读取资源的问题)导致PHP-CGI进程终止。

Nginx 504网关超时表示请求的网关没有被请求,简单来说就是可执行的PHP-CGI没有被请求。

解决这两个问题,其实需要综合思考。一般来说Nginx 502坏网关和php-fpm.conf的设置有关,

The timeout of Nginx 504 gateway is related to the setting of nginx.conf.

正确的设置需要考虑服务器本身的性能、访客数量等多重因素。

以我现在的服务器为例。CPU为奔腾4 1.5G,内存为1GB,centos系统约有50个访客同时在线。

但是大部分上网的人需要向PHP-CGI询问大量的信息处理,所以我把nginx.conf设置为:

fastcgi_connect_timeout 300s;

fastcgi_send_timeout 300s;

fastcgi_read_timeout 300s;

fastcgi_buffer_size 128k;

fastcgi_buffers 8 128k;#8 128

fastcgi_busy_buffers_size 256k;

fastcgi_temp_file_write_size 256k;

fastcgi_intercept_errors on;

这里最重要的设置是前三项,即

fastcgi_connect_timeout 300s;

fastcgi_send_timeout 300s;

fastcgi_read_timeout 300s;

PHP-CGI的连接、发送、读取时间都在这里指定,300秒就够了,所以我的服务器很少出现504网关超时的错误。最重要的是php-fpm.conf的设置

This will directly lead to 502 error gateway and 504 gateway timeout.

我们来仔细分析一下php-fpm.conf的几个重要参数:

Php-fpm.conf有两个至关重要的参数,一个是“max_children”,另一个是“request_terminate_timeout”。

我的两个设置一个是“40”,一个是“900”,但是这个值不是通用的,需要自己计算。

计算的方式如下:

如果你的服务器性能足够好,且宽带资源足够充足,PHP脚本没有系循环或BUG的话你可以直接将”request_terminate_timeout”设置成0s。

0s的含义是让PHP-CGI一直执行下去而没有时间限制。而如果你做不到这一点,也就是说你的PHP-CGI可能出现某个BUG,

或者你的宽带不够充足或者其他的原因导致你的PHP-CGI能够假死那么就建议你给”request_terminate_timeout”赋一个值,这个值可以根据你服务器的性能进行设定。

一般来说性能越好你可以设置越高,20分钟-30分钟都可以。由于我的服务器PHP脚本需要长时间运行,有的可能会超过10分钟因此我设置了900秒,

这样不会导致PHP-CGI死掉而出现502 Bad gateway这个错误。

而”max_children”这个值又是怎么计算出来的呢?这个值原则上是越大越好,php-cgi的进程多了就会处理的很快,排队的请求就会很少。

设置”max_children”也需要根据服务器的性能进行设定,一般来说一台服务器正常情况下每一个php-cgi所耗费的内存在20M左右,因此我的”max_children”我设置成40个,

20M*40=800M也就是说在峰值的时候所有PHP-CGI所耗内存在800M以内,低于我的有效内存1Gb。而如果我的”max_children”设置的较小,比如5-10个,

那么php-cgi就会“很累”,处理速度也很慢,等待的时间也较长。如果长时间没有得到处理的请求就会出现504 Gateway Time-out这个错误,

而正在处理的很累的那几个php-cgi如果遇到了问题就会出现502 Bad gateway这个错误。

相关文章:
  • 4月6日基金净值:圆信永丰优享生活最新净值2.271,涨1.28%_基金频道_证券之星
  • 34家公募砸逾百亿,谢治宇、朱少醒、周海栋出手,嗅到了什么?
  • 7月4日基金净值:华夏内需驱动混合A最新净值0.5731
  • 6月12日基金净值:鹏华招华一年持有期混合A最新净值1.0903,跌0.16%
  • 6月9日基金净值:银河沪深300价值指数A最新净值1.569,涨0.06%
  • 3月27日基金净值:富国丰利增强债券最新净值1.1987,跌0.06%_基金频道_证券之星
  • 5月15日基金净值:交银均衡成长一年混合A最新净值0.9247,涨1.38%
  • 7月3日基金净值:国寿安保成长优选股票A最新净值1.392,跌0.43%
  • 5月5日基金净值:嘉实品质回报混合最新净值0.7268,涨0.53%
  • 华泰柏瑞中证沪港深创新药ETF净值下跌3.94% 请保持关注