服务器环境:linux+nginx+php+mysql俗称的LNMP

首先,介绍我出现这个错误的时候的调试过程:

1,怀疑数据库连接出现问题,因为两个需要连接数据库的项目出现问题,其余不需要连接数据库的反而没有出现问题
2,根据error.log定位到php-fpm。网上也有很多说502是因为php-fpm配置出现问题
3,systemctl status php-fpm.service,php-fpm不能正常运行,原因在于 Failed to start The PHP FastCGI Process
4,定位错误至FastCGI Process
5,netstat -anpo | grep “php-cgi” | wc -l,显示为0,即FastCGI Process未能启动
6,未能生成/run/php-fpm/php-fpm.pid
7,通过该命令启动php-fpm:/usr/sbin/php-fpm,错误提示:ERROR: [/etc/php-fpm.d/www.conf:412] unknown directive ':php_flag'
8,突然想到之前配置文件为了开启php错误提示功能,我修改过php_flag这个参数

9,通过查找配置文件/etc/php-fpm.d/www.conf发现是自己之前误将注释符号;写成:了

10,修改回来,重启nginx服务,访问网页发现错误已经解决了

总结,502错误往往是由于:NGINX 502 Bad Gateway错误是FastCGI有问题,而FastCGI又和php-fpm密切相关。

调试该类错误会需要用到的命令:

命令一:
#测试php-fpm配置
/usr/local/php/sbin/php-fpm -t
/usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini -y /usr/local/php/etc/php-fpm.conf -t
 
#启动php-fpm
/usr/local/php/sbin/php-fpm
/usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini -y /usr/local/php/etc/php-fpm.conf
 
#关闭php-fpm
kill -INT `cat /usr/local/php/var/run/php-fpm.pid`
 
#重启php-fpm
kill -USR2 `cat /usr/local/php/var/run/php-fpm.pid`




命令二:
重启或重载nginx,和php-fpm
service php-fpm restart


service nginx restart


命令三:
显示FastCGI Process数量
netstat -anpo | grep “php-cgi” | wc -l等其余netstat命令配合使用,用于诊断错误原因。

Logo

更多推荐