502 proxy error解决方法_Nginx常见故障502等解决方案汇总,你掌握了吗?

v2-2671cc8044b35edbc52d0825c2611184_1440w.jpg?source=172ae18b

常见的Nginx 502 Bad Gateway解决办法如下:

Nginx 502错误情况1:

网站的访问量大,而php-cgi的进程数偏少。

针对这种情况的502错误,只需增加php-cgi的进程数。具体就是修改/usr/local/php/etc/php-fpm.conf 文件,将其中的max_children值适当增加。这个数据要依据你的VPS或独立服务器的配置进行设置。一般一个php-cgi进程占20M内存,你可以自己计算下,适量增多。

/usr/local/php/sbin/php-fpm restart 然后重启一下.

Nginx 502错误情况2:

CPU占用率、内存占用率非常高,遭到CC攻击.

解决方法请参考:LinuxVPS简单解决CC攻击

这里大家可以关注一下我的个人专栏《PHP进阶集中营》,每天会给大家即时分享一个最新的php技术资讯,有优秀的PHP技术内容,也欢迎分享在我的专栏。

PHP进阶集中营​zhuanlan.zhihu.com
v2-6929cbf759d21053b9dc57a7cec46b11_ipico.jpg

Nginx 502错误情况3:

CPU占用率不高,内存溢出。

检查一下网站程序有没有问题?一般小偷站点常常会出现内存溢出。

检查一下/var/log/目录下的日志,看看是不是有人爆破SSH和FTP端口?

SSH、FTP遭到穷举也会占用大量内存。是的话改掉SSH端口和FTP端口即可

将网上找到的一些和502 Bad Gateway错误有关的问题和排查方法列一下,先从FastCGI配置入手:

1.查看FastCGI进程是否已经启动

NGINX 502错误的含义是sock、端口没被监听造成的。我们先检查fastcgi是否在运行

2.检查系统Fastcgi进程运行情况

除了第一种情况,fastcgi进程数不够用、php执行时间长、或者是php-cgi进程死掉也可能造成nginx的502错误
运行以下命令判断是否接近FastCGI进程,如果fastcgi进程数接近配置文件中设置的数值,表明worker进程数设置太少

netstat 

3.FastCGI执行时间过长

根据实际情况调高以下参数值

fastcgi_connect_timeout 

4.头部太大

nginx和apache一样,有前端缓冲限制,可以调整缓冲参数

fastcgi_buffer_size 

如果你使用的是nginx的负载均衡Proxying,调整

proxy_buffer_size 

5.https转发配置错误

正确的配置方法

server_name 

6 max-children和max-requests

一台服务器上运行着nginx php(fpm) xcache,访问量日均 300W pv左右

最近经常会出现这样的情况: php页面打开很慢,cpu使用率突然降至很低,系统负载突然升至很高,查看网卡的流量,也会发现突然降到了很低。这种情况只持续数秒钟就恢复了

检查php-fpm的日志文件发现了一些线索:

Sep3008

在这几句的前面,是1000多行的关闭children和开启children的日志

原来,php-fpm有一个参数 max_requests,该参数指明了,每个children最多处理多少个请求后便会被关闭,默认的设置是500。因为php是把请求轮询给每个children,在大流量下,每个childre到达max_requests所用的时间都差不多,这样就造成所有的children基本上在同一时间被关闭。

在这期间,nginx无法将php文件转交给php-fpm处理,所以cpu会降至很低(不用处理php,更不用执行sql),而负载会升至很高(关闭和开启children、nginx等待php-fpm),网卡流量也降至很低(nginx无法生成数据传输给客户端)

解决问题很简单,增加children的数量,并且将 max_requests 设置未 0 或者一个比较大的值:

打开 /usr/local/php/etc/php-fpm.conf

调大以下两个参数(根据服务器实际情况,过大也不行)

<

然后重启php-fpm。

7、增加缓冲区容量大小

将nginx的error log打开,发现“pstream sent too big header while reading response header from upstream”这样的错误提示。查阅了一下资料,大意是nginx缓冲区有一个bug造成的,我们网站的页面消耗占用缓冲区可能过大。参考老外写的修改办法增加了缓冲区容量大小设置,502问题彻底解决。后来系统管理员又对参数做了调整只保留了2个设置参数:client head buffer,fastcgi buffer size。

8、request_terminate_timeout

如果主要是在一些post或者数据库操作的时候出现502这种情况,而不是在静态页面操作中常见,那么可以查看一下php-fpm.conf设置中的一项:request_terminate_timeout

这个值是max_execution_time,就是fast-cgi的执行脚本时间。

0s为关闭,就是无限执行下去。

发现问题解决了,执行很长时间也不会出错了。

优化fastcgi中,还可以改改这个值为5s 看看效果。

php-cgi进程数不够用、php执行时间长、或者是php-cgi进程死掉,都会出现502错误。

PHP进阶学习笔记、面试;文档、视频资源免费获取​shimo.im
v2-6d1011dcaf7d98b852f02a2c9f61aa1d_120x160.jpg
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Nginx 502 Bad Gateway错误通常是由于Nginx服务器无法从上游服务器接收到有效的响应引起的。出现这个错误可能有以下几种解决方法: 1. 检查上游服务器:502错误可能是由于上游服务器故障引起的。因此,首先要确保上游服务器正常运行,并且能够正确地响应请求。 2. 检查Nginx配置:有时候配置文件中的某些设置可能会导致502错误。检查Nginx配置文件(通常是nginx.conf)是否正确配置了上游服务器的地址和端口,并且代理设置是否正确。 3. 增加缓冲区大小:如果上游服务器响应较慢,Nginx默认的缓冲区大小可能不足以处理大量请求。可以尝试增加proxy_buffers和proxy_buffer_size参数的值来扩大缓冲区大小,以提高代理的性能。 4. 调整超时设置:如果上游服务器响应超时,也会导致502错误。可以尝试调整proxy_connect_timeout、proxy_send_timeout和proxy_read_timeout参数的值来增加超时时间。 Nginx 504 Gateway Time-out错误表示上游服务器在规定的时间内未能及时响应请求。解决这个错误的方法包括: 1. 调整超时设置:可以适当增加proxy_connect_timeout、proxy_send_timeout和proxy_read_timeout参数的值来给上游服务器更多的时间来响应请求。 2. 检查上游服务器:确保上游服务器正常运行,并且能够及时响应请求。 3. 检查负载均衡设置:如果Nginx配置了负载均衡,可以尝试调整负载均衡算法或增加上游服务器的数量,以提高整体性能和稳定性。 4. 使用缓存:可以使用缓存来减少对上游服务器的请求,通过缓存来提供部分请求的响应。 以上是常见解决Nginx 502 Bad Gateway和504 Gateway Time-out错误的方法,具体解决办法可能因环境和问题的具体情况而有所不同。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值