访问 LNMP 报 502 Bad Gateway 错误的解决办法

时间:2021-03-13 08:12:16

LNMP : Linux + Nginx + MySQL + PHP

Nginx 出现502有很多原因,但大部分原因可以归结为资源数量不够用,也就是说后端 PHP-FPM 处理有问题,Nginx 将正确的客户端请求发给了后端的 php-fpm 进程,但是因为 php-fpm 进程的问题导致不能正确解析 php 代码,最终返回给了客户端 502 错误。

Nginx + PHP 出现 502 bad gateway,一般这都不是 Nginx 的问题,而是由于 fastcgi 或者 php 的问题导致的,常见的有以下几种(其实解决问题的最好的方式还是自己去看 nginx 和 fastcgi 的 errorlog ):

1、PHP 的配置文件 php.ini 中的 memory_limit 值设置过小。
      如果有个别 php 程序进程需要占用极大内存时这个必须注意.。

2、PHP 的配置文件 php-fpm.conf 中 max_children 值或者 max_requests 值设置不合理

设置过小会因为没有足够的 cgi进程处理请求,设置过大会出现一会儿有响应正常,一会儿等很久才有响应的情况。
      一般情况下 max_children 按照内存计算,比如说1G设置64,2G设置为128。这个根据实际情况自行调整。
      另外查看当前的 PHP FastCGI 进程数是否够用的命令为:
            netstat -anpo |grep “php-cgi” | wc -l
      如果实际使用的“FastCGI进程数”接近预设的“FastCGI进程数”,那么,说明“FastCGI进程数”不够用,需要增大。

3、查看 Nginx 服务的错误日志
      查看 Nginx 服务的错误日志,发现 pstream sent too big header while reading response headerfrom upstream ,则检查client_head_buffer、fastcgi_buffer_size 是否过小,可设置为32K。

4、php 程序执行时间过长而超时,检查 Nginx 和 fastcgi 中各种timeout设置。
      nginx 中:
            fastcgi_connect_timeout 300;
            fastcgi_send_timeout 300;
            fastcgi_read_timeout 300;
            keepalive_timeout;

php-fpm 中:
            request_terminate_timeout

php.ini中:
            max_execution_time

5、PHP-FPM 中 max_requests 参数设置问题
      PHP-FPM 有一个参数 max_requests ,该参数指明了每个children最多处理多少个请求后便会被关闭。
      在大量处理请求下,如果该值设置过小会导致 children 频繁的自杀和建立而浪费大量时间,
      若所有的children差不多都在这个时候自杀,则重建前将没有children响应请求,于是出现502。
      可以将该值设置大一些或者是0[无限]。(生产环境不建议设置为 0)

如果你服务器并发量非常大,那只能先增加机器,然后按以下方式优化会取得更好效果;但如果你并发不大却出现502,一般都可以归结为配置问题,脚本超时问题。