520BadGateway错误解决办法

本文记录了一次解决LNMP环境下502错误的过程,包括定位问题至php-fpm及FastCGI进程,最终发现并修正了配置文件中的错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

服务器环境: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命令配合使用,用于诊断错误原因。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大音若希

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值