“Nginx 502 Bad Gateway”错误的含义是请求的PHP-CGI已经执行,但是由于读取资源问题等原因没有执行完毕,而导致PHP-CGI进程终止,一般来说“Nginx 502 Bad Gateway”错误和php-fpm.conf的设置有关。
常见的原因可能是php-cgi进程数不够用、MySQL语句执行慢导致PHP执行时间长、或者是php-cgi进程异常中断,都会出现502错误。
针对不同的问题原因,提供以下不同的解决方法。当磁盘空间不足时,可以执行df -h
命令,查看磁盘使用量。
在Nginx安装后可正常访问网站的环境中,运行一段时间出现502错误码,一般默认php-cgi进程是5个,可能因为php-cgi进程不够用而造成502错误,需要修改/usr/local/php/etc/php-fpm.conf
文件,将其中的max_children值适当增加。
PHP执行超时,修改/usr/local/php/etc/php.ini
文件,将max_execution_time改为300。
通常的排查方法如下。
netstat -anop | grep php-cgi | wc -l系统显示类似如下。
netstat -anpo | grep php-fpm | wc -l
ps aux | grep php-fpm系统显示类似如下,观察fastcgi、php-fpm进程数,假如使用的进程数等于或高于5个,说明需要增加。
/usr/local/php/etc/php-fpm.conf
配置文件中的相关参数,将pm.max_children参数的值修改为5,将request_terminate_timeout参数的值修改为60。
注:
- max_children最多5个进程,按照每个进程20MB内存,最多100MB。也就是1分钟。max_children增多,则php-cgi的进程增多就会处理的很快,排队的请求就会很少。但是设置max_children也需要根据服务器的性能进行设定,一台服务器正常情况下,每一个php-cgi进程所耗费的内存在20M左右。根据购买的服务器内存来实际决定。
- request_terminate_timeout执行的时间为60秒,request_terminate_timeout值可以根据服务器的性能进行设定。一般来说性能越好您可以设置越高,20分钟~30分钟都可以。