我的编程空间,编程开发者的网络收藏夹
学习永远不晚

nginx服务器异常502 bad gateway原因排查

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

nginx服务器异常502 bad gateway原因排查

服务器进行公众号粉丝数据同步以及批量推送报错502

根据错误信息可以判定是后端的问题,502错误的原因有很多种,但总的来说就是服务器处理不过来了

1.首先查看服务器日志
1)先查nginx日志,不熟悉的可以从nginx.conf中获取error_log的路径,找到错误如下:

在这里插入图片描述

发现nginx进程处理的连接数不够用,单个进程处理的连接数超过了nginx.conf配置的worker_connections值

在这里插入图片描述

通常worker_connections的值可以参考单个进程打开的最大连接数,命令为:ulimit -n
ulimit -a 查看所有限制参数
当前最大打开文件数:65535,可以设置worker_connections为51200

重启nginx nginx -s reload


查看当前tcp连接状况 
netstat -an|awk '/^tcp/{++S[$NF]}END{for (a in S)print a,S[a]}'

2)查看php-fpm日志,同样不熟悉日志位置可以从php-fpm.conf中查看,注意php7以上的配置文件是放在php-fpm.d目录下的www.conf

查看php-fpm.log

在这里插入图片描述

发现pm.max_children不够用了,说明php-fpm最大进程数太小了,查看php配置文件ww.conf,修改改参数pm.max_children=100

php-fpm主要调整几个参数
pm = dynamic 如何控制子进程,选项有static和dynamic


pm.max_children:静态方式下开启的php-fpm进程数量

pm.max_requests:php-fpm子进程能处理的最大请求数

pm.start_servers:动态方式下的起始php-fpm进程数量
pm.min_spare_servers:动态方式下的最小php-fpm进程数
pm.max_spare_servers:动态方式下的最大php-fpm进程数量

一、pm.max_children,pm.max_spare_servers 多大合适?


这个值原则上是越大越好,php-cgi的进程多了就会处理的很快,排队的请求就会很少。
设置”max_children” 也需要根据服务器的性能进行设定。

数量也可以根据 内存/30M 得到,比如8GB内存可以设置为100,那么php-fpm耗费的内存就能控制在 2G-3G的样子。

对于小内存的服务器来说,比如256M内存的VPS,即使按照一个20M的内存量来算,10个php-cgi进程就将耗掉200M内存,那系统的崩溃就应该很正常了。

因此应该尽量地控制php-fpm进程的数量,大体明确其他应用占用的内存后,
给它指定一个静态的小数量,会让系统更加平稳一些。或者使用动态方式,
因为动态方式会结束掉多余的进程,可以回收释放一些内存,所以推荐在内存较少的服务器或VPS上使用。具体最大数量根据 内存/30M 得到。

pm.start_servers缺省值计算公式: min_spare_servers + (max_spare_servers - min_spare_servers) / 2。

比如说512M的VPS,加入分配给php-fpm最大250M,建议pm.max_spare_servers设置为250/30 ,约为8。至于pm.min_spare_servers,则建议根据服务器的负载情况来设置,比如服务器上只是部署php环境的话,比较合适的值在2~5之间。

这里面还有一个问题,php-fpm因为一些第三方库可能会引起内存泄漏,时间长了,占用的内存会比较多,像我们的服务器现在就是50m左右,还好,有pm.max_requests这个参数,这个参数指定了一个php-fpm子进程执行多少次之后重启该进程。这个可能就要根据你的实际情况调整了。

计算方式如下:

一般来说一台服务器正常情况下每一个php-cgi所耗费的内存在20M~30M左右,因此我的”max_children”我设置成40个,20M*40=800M也就是说在峰值的时候所有PHP-CGI所耗内存在800M以内,低于我的有效内存2Gb。

而如果我 的”max_children”设置的较小,比如5-10个,那么php-cgi就会“很累“,处理速度也很慢,等待的时间也较长,占用的CPU也很高。

如果长时间没有得到处理的请求就会出现 504 Gateway Time-out 这个错误,而正在处理的很累的那几个php-cgi如果遇到了问题就会出现 502 Bad gateway 这个错误。


max_children较好的设置方式根据req/s
(吞吐率,单位时间里服务器处理的最大请求数,单位req/s)来设置,
若程序是 100 req/s 的处理能力,那么就设置 100比较好,这是动态来调整的。

二、request_terminate_timeout 多大合适?

计算方式如下:

如果你的服务器性能足够好,且宽带资源足够充足,PHP脚本没有循环或BUG的话你可以直接将”request_terminate_timeout”设 置成0s。0s的含义是让PHP-CGI一直执行下去而没有时间限制。

而如果你做不到这一点,也就是说你的PHP-CGI可能出现某个BUG,或者你的宽带不够充足或者其他的原因导致你的PHP-CGI能够假死那么就建议你给”request_terminate_timeout”赋一个值,这个值可以根 据你服务器的性能进行设定。

一般来说性能越好你可以设置越高,20分钟-30分钟都可以。由于我的服务器PHP脚本需要长时间运行,有的可能会超过10分钟因此我设置了900秒,这样不会导致PHP-CGI死掉而出现502 Bad gateway这个错误。

优化后的参数

编辑/usr/local/php/etc/php-fpm.d/www.conf:
服务器配置:2核8G
pm = dynamic
pm.start_servers = 5
pm.min_spare_servers = 2
pm.max_spare_servers = 100

request_terminate_timeout=1200

查出服务的进程id
ps aux |grep php-fpm
kill -9 进程id 常用来杀死僵尸进程

总结nginx出现502错误原因

二、代理缓冲区设置过小
如果你使用的是nginx反向代理,如果header过大,超出了默认的1k,就会引发上述的upstream sent too big header (说白了就是nginx把外部请求给后端处理,后端返回的header太大,nginx处理不过来就会导致502。

server {


listen       80;
server_name  *.lxy.me;

location / {

添加这3行
fastcgi_buffer_size 64k;
fastcgi_buffers 32 32k;
fastcgi_busy_buffers_size 128k;
添加这3行
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
…………
}

三、默认php-cgi的进程数设置过少
在安装好使用过程中出现502问题,一般是因为默认php-cgi进程是5个,可能因为phpcgi进程不够用而造成502,需要修改/usr/local/php/etc/php-fpm.conf 将其中的max_children值适当增加。也有可能是max_requests值不够用。需要说明的是这连个配置项占用内存很大,请根据服务器配置进行设置。否则可能起到反效果。

四、php执行超时
php执行超时,修改/usr/local/php/etc/php.ini 将max_execution_time 改为300

五、nginx等待时间超时
部分PHP程序的执行时间超过了Nginx的等待时间,可以适当增加nginx.conf配置文件中FastCGI的timeout时间

http {
fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
……
}

六、如果做公众号这一块,注意有可能是微信服务器请求自己服务器过多导致的
如果发现php-fpm进程数已经达到最大的进程数,查看php-fpm配置文件,可以看到错误信息

到此这篇关于nginx服务器异常502 bad gateway原因排查的文章就介绍到这了,更多相关nginx服务器异常502 bad gateway内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

nginx服务器异常502 bad gateway原因排查

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何解决nginx服务器异常502 bad gateway错误的问题

小编给大家分享一下如何解决nginx服务器异常502 bad gateway错误的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!服务器进行公众号粉丝数据同步以
2023-06-20

香港阿里云服务器异常原因

很抱歉,我不了解具体的香港阿里云服务器异常原因。如果您遇到服务器异常,您可以按照以下步骤尝试诊断和解决问题:检查服务器是否正常启动:使用服务器管理工具(例如:Git等)来检查服务器是否正常启动。检查网络连接:检查服务器与互联网之间的连通性,确保服务器能够正常获取网络资源。如果网络连接无法解决,请尝试重启服务器。确认服务器配置:检查服务器配置是否正确,例如:是否正确安装了操作系统、驱动程序
2023-10-26

tracker服务器连接异常的原因有哪些

tracker服务器连接异常的原因有:1、主机系统出现宕机,蓝屏等情况,导致服务器连接异常;2、服务器资源不足,导致延迟高,访问变卡,连接出现异常;3、服务器中病毒,主机上的远程端口被关闭或登录信息遭到修改,导致服务器连接异常。具体内容如下
2023-02-08

香港阿里云服务器异常原因分析

阿里云服务器异常原因通常会有多种情况,以下是一些常见的原因:应用程序错误:如果应用程序在进行某些操作时出现问题,例如文件损坏、权限问题等,可能会导致应用程序崩溃并无法继续运行。内存问题:如果内存不足或分配不正确,应用程序可能会崩溃并导致数据丢失。配置错误:如果应用程序在使用某些配置或操作时出现错误,例如不正确的配置、权限问题或网络问题,可能会导致应用程序异常和数据丢失。网络问题:如果服务不稳定,可能会导致应用...
2023-10-26

香港阿里云服务器异常原因有哪些

1.网络问题阿里云服务器在香港地区的异常可能与网络问题有关。网络问题可能包括网络延迟、网络拥塞、网络故障等。这些问题可能导致服务器无法正常连接到互联网,或者导致服务器的响应速度变慢。2.硬件故障阿里云服务器在香港地区的异常也可能与硬件故障有关。硬件故障可能包括硬盘故障、内存故障、CPU故障等。这些故障可能导致服务器无法正常运行,或者导致服务器的性能下降。3.软件问题阿里云服务器在香港地
2023-10-26

服务器自动重启的原因及如何排查

服务器自动重启的原因可能包括以下几种:硬件问题:可能是服务器硬件出现故障,导致服务器自动重启。软件问题:可能是服务器上的某些软件或驱动程序出现了问题,导致系统崩溃并自动重启。系统更新:有些系统更新可能需要重启服务器来生效。电源问题:可
服务器自动重启的原因及如何排查
2024-04-20

香港阿里云服务器异常原因是什么

阿里云是一家知名的云计算服务提供商,为企业和个人提供云计算基础设施和应用程序服务。其主要服务包括计算、存储、网络、安全等方面的解决方案,可以帮助用户构建和管理高效、稳定的云计算平台。然而,阿里云服务器的故障和问题并不是个例,这通常是由于多种原因引起的。例如,硬件故障、软件缺陷、网络故障等。其中,硬件故障是最常见的原因,
香港阿里云服务器异常原因是什么
2023-10-28

dns服务器地址设置异常的原因有哪些

1. 错误的IP地址输入:输入错误的IP地址或格式不正确的IP地址会导致DNS服务器地址设置异常。2. 网络连接问题:网络连接不稳定或中断会导致DNS服务器地址设置异常。3. 防火墙/安全软件:防火墙或安全软件可能会阻止DNS服务器地址的设
2023-06-11

阿里云服务器运行服务器异常原因及解决办法

本文将详细介绍阿里云服务器运行服务器异常的原因以及解决办法。希望通过这篇文章,帮助读者了解如何快速诊断和解决阿里云服务器运行过程中可能出现的问题。一、阿里云服务器运行服务器异常的原因系统更新:阿里云服务器运行服务器异常,可能是由于系统更新导致的。系统更新可能会带来一些未知的问题,导致服务器运行异常。硬件问题:阿里
阿里云服务器运行服务器异常原因及解决办法
2023-12-17

香港阿里云服务器异常原因有哪些呢

事件背景:阿里云服务器是一种云服务,可以在多种平台上运行。但是,由于某些原因,一些云服务供应商(如亚马逊、微软、谷歌等)会出现故障或错误,这些问题可能会导致应用程序或网站无法正常运行。这种情况可能会对用户的业务造成不利影响,因此需要采取适当的措施来解决。事件经过:某研究团队使用阿里云服务器时遇到了以下问题:访问速度慢该
香港阿里云服务器异常原因有哪些呢
2023-10-28

亚马逊服务器显示异常:解决方法和常见原因

1.服务器异常的常见原因亚马逊服务器显示异常可能是由多种原因引起的。以下是一些常见的原因:1.1网络连接问题亚马逊服务器可能由于网络连接问题而显示异常。这可能是由于网络故障、路由器问题或者互联网服务提供商(ISP)的问题导致的。1.2服务器负载过高如果服务器上的负载过高,可能会导致服务器显示异常。这可能是由于流量激增、恶意攻击或者应用程序错误导致的。1.3软件错误服务器上的软件错误也可能导致服务器显示异常。这...
2023-10-27

香港阿里云服务器异常原因分析报告

近期,香港阿里云服务器出现了一些异常情况,导致大量用户无法正常使用。这一异常情况引起了广泛关注和担忧。为了更好地理解问题的原因,我们需要从服务器的硬件、软件、网络等多个方面进行分析。一、硬件方面服务器硬件问题:服务器硬件故障是导致异常情况发生的主要原因之一。例如,硬盘损坏、内存故障、网络故障等。这些硬件故障会导致服务器无法正常运行,给用户带来很大的损失。软件方面问题:服务器的软件也是影响服务器正常...
2023-10-27

阿里云服务器提醒服务异常原因与解决方法

简介:本文将详细介绍阿里云服务器提醒服务出现异常的原因,以及如何进行有效的故障排除和修复。在使用阿里云服务器的过程中,可能会遇到各种问题。其中,服务器提醒服务异常是一个常见的问题,这不仅可能影响到用户的正常操作,也可能导致数据丢失。那么,为什么会发生这种问题呢?又该如何解决呢?让我们一起来探讨这些问题。原因分析首先,我
阿里云服务器提醒服务异常原因与解决方法
2024-01-26

编程热搜

目录