2013-10-14 16:44:01
来 源
ITJS.CN
Nginx
这里分享一下如何解决Nginx502BADGateWay错误,希望对于初学Nginx服务器相关的朋友有帮助,更多Nginx安装、配置、报错处理等资源请本站内搜索。。

Nginx 502 BAD GateWay错误解决方法

今天,我的VPS提示Nginx 502 Bad Gateway错误了,很烦。我什么事情都没做呀,有点想不通,怎么这次就出现了502 Bad Gateway?郁闷啊!在搜索了一下,发现一篇文库文档,终于找到了不少相关的答案,希望修改之后不会再出现这个错误了。现在写出来,给大家一个参考。

首先我ping网站能通,DNS解析也是正常的,反问html网页是正常的,但是访问php就有问题,说明问题出在PHP上。

我用的是LNMP一键安装包官方的:

(我直接重启lnmp就临时解决了,但这不是根本办法)

第一种原因:目前lnmp一键安装包比较多的问题就是502 Bad Gateway,大部分情况下原因是在安装php前,脚本中某些lib包可能没有安装上,造成php没有编译安装成功或者php-fpm 没有运行,这条很重要

查看php-fpm有没有运行:ps -A | grep php-cgi

[email protected]:/etc/init.d# ps -A | grep php-cgi

6037 ? 00:00:00 php-cgi

6039 ? 00:00:04 php-cgi

6040 ? 00:00:00 php-cgi

6041 ? 00:00:00 php-cgi

6042 ? 00:00:00 php-cgi

6043 ? 00:00:04 php-cgi

6044 ? 00:00:04 php-cgi

6045 ? 00:00:00 php-cgi

如果没有看到php-cgi 进程则启动即可,统计进程总数用:ps -A | grep php-cgi | wc -l

启动方法:/etc/init.d# /etc/init.d/php-fpm start

第二种原因:

在php.ini里,eaccelerator配置项一定要放在Zend Optimizer配置之前,否则也可能引起502 Bad Gateway

第三种原因:

在安装好使用过程中出现502问题,一般是因为默认php-cgi进程是5个,可能因为phpcgi进程不够用而造成502,需要修改/usr/local/php/etc/php-fpm.conf 将其中的max_children值适当增加。

第四种原因:

php执行超时,修改/usr/local/php/etc/php.ini 将max_execution_time 改为300

第五种原因:

磁盘空间不足,如mysql日志占用大量空间

我用df -hl 没有异常,才11%

第六种原因:

查看php-cgi进程是否在运行

也有网友给出了另外的解决办法:

Nginx 502 Bad Gateway的含义是请求的PHP-CGI已经执行,但是由于某种原因(一般是读取资源的问题)没有执行完毕而导致PHP-CGI进程终止,一般来说Nginx 502 Bad Gateway和php-fpm.conf的设置有关。

php-fpm.conf有两个至关重要的参数,一个是max_children,另一个是request_terminate_timeout,但是这个值不是通用的,而是需要自己计算的。

在安装好使用过程中出现502问题,一般是因为默认php-cgi进程是5个,可能因为phpcgi进程不够用而造成502,需要修改/usr/local/php/etc/php-fpm.conf 将其中的max_children值适当增加。

计算的方式如下:

如果你的服务器性能足够好,且宽带资源足够充足,PHP脚本没有系循环或BUG的话你可以直接将 request_terminate_timeout设置成0s。0s的含义是让PHP-CGI一直执行下去而没有时间限制。而如果你做不到这一点,也就 是说你的PHP-CGI可能出现某个BUG,或者你的宽带不够充足或者其他的原因导致你的PHP-CGI假死那么就建议你给 request_terminate_timeout赋一个值,这个值可以根据服务器的性能进行设定。一般来说性能越好你可以设置越高,20分钟-30分 钟都可以。

而max_children这个值又是怎么计算出来的呢?这个值原则上是越大越好,php-cgi的进程多了就会处理的很快,排队的请求就会很少。 设置max_children也需要根据服务器的性能进行设定,一般来说一台服务器正常情况下每一个php-cgi所耗费的内存在20M左右。

按照官方的答案,排查了相关的可能,并结合了网友的答案,得出了下面的解决办法。

1、查看php fastcgi的进程数(max_children值)

代码:netstat -anpo | grep “php-cgi” | wc -l

5(假如显示5)

我服务器查看居然是144,还吓人。我的网站访问量并不高,太奇怪了。

2、查看当前进程

代码:top

观察fastcgi进程数,假如使用的进程数等于或高于5个,说明需要增加(根据你机器实际状况而定)

3、调整/usr/local/php/etc/php-fpm.conf 的相关设置

<value name="max_children">10</value>

<value name=”request_terminate_timeout”>60s</value>

max_children最多10个进程,按照每个进程20MB内存,最多200MB。

request_terminate_timeout执行的时间为60秒,也就是1分钟。

我的服务器按照最后这条调整后重启lnmp就正常了.

5月19日用Wordpress后台时又出现"no input file specified"问题了,但是网站访问没问题,后然我才发现是WP后台网站路径不对,比如说网址/edit.php 真确的路径应该是/wp-admin/edit.php 不知道后台为什么会出错,后然手工输入正确的URL又一直工作正常了。后然发现原来是登陆时wp-admin后面没跟"/",导致路径错误。

注意API站点,蜘蛛抓取会耗费大量资源!!!

声明: 此文观点不代表本站立场;转载须要保留原文链接;版权疑问请联系我们。