Nginx 502 Bad
Gateway的含义是请求的PHP-CGI已经执行,但是由于某种原因(一般是读取资源限制的问题)没有执行完毕而导致PHP-CGI进程终止,查看php-fpm有没有运行:
# ps aux | grep php-cgi
解决方法就是重新启动此服务进程即可,启动方法:# /etc/init.d/php-fpm start 。
附上其它可能的原因供排除:
php执行超时,修改/usr/local/php/etc/php.ini 将max_execution_time 改为300或更高
磁盘空间不足,如mysql日志占用大量空间
一般来说Nginx
502 Bad Gateway和php-fpm.conf的设置有关,php-fpm.conf有两个至关重要的参数,一个是max_children,另一个是request_terminate_timeout,但是这个值不是通用的,而是需要自己计算的。
设置max_children也需要根据服务器的性能进行设定,一般来说一台服务器正常情况下每一个php-cgi所耗费的内存在20M左右,调整/usr/local/php/etc/php-fpm.conf 的方法为:
<value name="max_children">10</value>
max_children 最多10个进程,按照每个进程20MB内存,最多200MB。
request_terminate_timeout执行的时间为60秒,也就是1分钟。
# ps aux | grep php-cgi
解决方法就是重新启动此服务进程即可,启动方法:# /etc/init.d/php-fpm start 。
附上其它可能的原因供排除:
第一种原因:
在php.ini里,eaccelerator配置项一定要放在Zend Optimizer配置之前,否则也可能引起502 Bad Gateway
在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日志占用大量空间
在安装好使用过程中出现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左右,调整/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。