深入探讨:Nginx 502 Bad Gateway错误的解决方法


Posted in PHP onJune 03, 2013

max_children=40 , 每个children平均占用20M-30M内存,children越多,可以同时接受的并发数量越多,一般children的值是网站最高并发数+浮动值,这值再×内存占用,就是你需要用到的内存。
max_requests = N 是指当每个children接受了N次请求以后,就会把自己杀死,然后重新建立一个children。
PV / max_children = 每一个children接受的request次数[ 默认预设浏览一个只调用一次PHP程序,或许异步调用呢?接口呢?]
比如上面的值是1000,而你定义的是10240,那么fpm要超过10天才能杀死children并重建,这样如果存在内存泄露的话,就会导致进程占用过多的内存而无法释放,从而使fpm的处理能力降低,还会产生一些莫名其妙的错误。
但是如果你把这个值设置的过小,fpm频繁的杀死children并重建,也会导致额外的开销。
最好的优化当然是根据你网站的运行情况,去不断的调试,找到一个平衡点。
针对max_children还有一个偷懒的做法,如果你的php是5.3,那么你可以把fpm的style设置为apache-like,这个时候children的数量就由fpm自动控制。相应的配置参数是
start_servers:起始进程数量
min_spare_servers:最小进程数量
max_spare_servers:最大进程数量
当服务器比较空闲的时候,fpm会主动杀死一些多余的children,用来节约资源,当服务器繁忙的时候,服务器会自动建立更多的children。
#########################
Nginx 502 Bad Gateway的含义是请求的PHP-CGI已经执行,但是由于某种原因(一般是读取资源的问题)没有执行完毕而导致PHP-CGI进程终止,
一般来说Nginx 502 Bad Gateway和php-fpm.conf的设置有关。
php-fpm.conf有两个至关重要的参数,一个是max_children,
另一个是request_terminate_timeout,但是这个值不是通用的,而是需要自己计算的。
在安装好使用过程中出现502问题,一般是因为默认php-cgi进程是5个,可能因为phpcgi进程不够用而造成502,需要修改/usr/local/php/etc/php-fpm.conf 将其中的max_children值适当增加。
计算的方式如下:

如果你的服务器性能足够好,且宽带资源足够充足,PHP脚本没有死循环或BUG的话你可以直接将 request_terminate_timeout设置成0s。0s的含义是让PHP-CGI一直执行下去而没有时间限制。而如果你做不到这一点,也就 是说你的PHP-CGI可能出现某个BUG,或者你的宽带不够充足或者其他的原因导致你的PHP-CGI假死那么就建议你给request_terminate_timeout赋一个值,这个值可以根据服务器的性能进行设定。一般来说性能越好你可以设置越高,20分钟-30分 钟都可以。

而max_children这个值又是怎么计算出来的呢?这个值原则上是越大越好,php-cgi的进程多了就会处理的很快,排队的请求就会很少。 设置max_children也需要根据服务器的性能进行设定,
一般来说一台服务器正常情况下每一个php-cgi所耗费的内存在20M左右。
按照官方的答案,排查了相关的可能,并结合了网友的答案,得出了下面的解决办法。
1、查看php fastcgi的进程数(max_children值)
代码:netstat -anpo | grep “php-cgi” | wc -l
5(假如显示5)
2、查看当前进程
代码:top
观察fastcgi进程数,假如使用的进程数等于或高于5个,说明需要增加(根据你机器实际状况而定)
3、调整/usr/local/php/etc/php-fpm.conf 的相关设置
<value name=”max_children”>10</value>
<value name=”request_terminate_timeout”>60s</value>
max_children最多10个进程,按照每个进程20MB内存,最多200MB。
request_terminate_timeout执行的时间为60秒,也就是1分钟。
#################################################
网站运行环境是Nginx +php fastcgi模式的。这几天运行一直不稳定,总是出错,报502错误。
今天跟以前的同事请教了一下,他告诉我检查一下php-fpm的日志,那里记录了很多有用的信息。
于是我检查了一下,发现确实有很多报错信息:
Sep 30 08:32:23.289973 [NOTICE] fpm_unix_init_main(), line 271: getrlimit(nofile): max:51200, cur:51200
如果和nginx.conf : worker_rlimit_nofile 65500; 不一致必须检查,设置重启服务
Mar 01 14:39:15.881047 [NOTICE] fpm_children_make(), line 352: child 12364 (pool default) started
Mar 01 14:39:21.715825 [NOTICE] fpm_got_signal(), line 48: received SIGCHLD
Mar 01 14:39:21.715899 [NOTICE] fpm_children_bury(), line 215: child 11947 (pool default) exited with code 0 after 175.443305 seconds from start

 
有的报错信息,就好说了,直接上网查信息。
经过搜索,最后总结出以下几条优化策略:
1、提升服务器的文件句柄打开打开
# vi /etc/security/limits.conf 加上
* soft nofile 65500
* hard nofile 65500
2、提升nginx的进程文件打开数
nginx.conf : worker_rlimit_nofile 65500;
3、修改php-fpm.conf文件,主要需要修改2处。
命令 ulimit -n 查看限制的打开文件数,php-fpm.conf 中的选项rlimit_files 确保和此数值一致。
<value name=”max_requests”>10240</value>
<value name=”rlimit_files”>65500</value>
4、
# vi /etc/sysctl.conf
底部添加
fs.file-max=65500
经过以上修改,重启PHP。/usr/local/webserver/php/sbin/php-fpm restart
在查看ulimit -n 是否生效,否则重启服务器或者/etc/sysctl.conf、/etc/security/limits.conf的配置生效
到目前为止还没有出现过以上的报错信息。一切运行正常。

PHP 相关文章推荐
文件上传的实现
Oct 09 PHP
BBS(php &amp; mysql)完整版(六)
Oct 09 PHP
深思 PHP 数组遍历的差异(array_diff 的实现)
Mar 23 PHP
php 传值赋值与引用赋值的区别
Dec 29 PHP
测试php连接mysql是否成功的代码分享
Jan 24 PHP
对PHP新手的一些建议(PHP学习经验总结)
Aug 20 PHP
php开发中的页面跳转方法总结
Apr 26 PHP
linux下为php添加iconv模块的方法
Feb 28 PHP
thinkphp配置文件路径的实现方法
Aug 30 PHP
php获取当前月与上个月月初及月末时间戳的方法
Dec 05 PHP
PHP+RabbitMQ实现消息队列的完整代码
Mar 20 PHP
PHP+MySQL实现在线测试答题实例
Jan 02 PHP
深入php-fpm的两种进程管理模式详解
Jun 03 #PHP
PHP 异步执行方法,模拟多线程的应用分析
Jun 03 #PHP
基于PHP异步执行的常用方式详解
Jun 03 #PHP
php生成二维码的几种方式整理及使用实例
Jun 03 #PHP
深入PHP异步执行的详解
Jun 03 #PHP
php实现自动获取生成文章主题关键词功能的深入分析
Jun 03 #PHP
基于MySQL到MongoDB简易对照表的详解
Jun 03 #PHP
You might like
syphon 虹吸式咖啡冲泡冲煮倒水的得与失
2021/03/03 冲泡冲煮
浅析php中如何在有限的内存中读取大文件
2013/07/02 PHP
easyui的tabs update正确用法分享
2014/03/21 PHP
php查找指定目录下指定大小文件的方法
2014/11/28 PHP
php实现给一张图片加上水印效果
2016/01/02 PHP
PHP实现的折半查询算法示例
2017/10/09 PHP
YUI 读码日记之 YAHOO.util.Dom - Part.1
2008/03/22 Javascript
用jquery实现学校的校历(asp.net+jquery ui 1.72)
2010/01/01 Javascript
如何在node的express中使用socket.io
2014/12/15 Javascript
bootstrap Validator 模态框、jsp、表单验证 Ajax提交功能
2017/02/17 Javascript
vue使用drag与drop实现拖拽的示例代码
2017/09/07 Javascript
springMvc 前端用json的方式向后台传递对象数组方法
2018/08/07 Javascript
jquery中为什么能用$操作
2019/06/18 jQuery
IE11下处理Promise及Vue的单项数据流问题
2019/07/24 Javascript
vue+elementUi图片上传组件使用详解
2019/08/20 Javascript
对layer弹出框中icon数字参数的说明介绍
2019/09/04 Javascript
Vue 中使用 typescript的方法详解
2020/02/17 Javascript
解决vue 给window添加和移除resize事件遇到的坑
2020/07/21 Javascript
[03:24][TI9纪实] Dota奶爸
2019/08/22 DOTA
对pycharm 修改程序运行所需内存详解
2018/12/03 Python
如何用python写一个简单的词法分析器
2018/12/18 Python
Django框架模板注入操作示例【变量传递到模板】
2018/12/19 Python
Python实现的调用C语言函数功能简单实例
2019/03/13 Python
对django2.0 关联表的必填on_delete参数的含义解析
2019/08/09 Python
PythonPC客户端自动化实现原理(pywinauto)
2020/05/28 Python
matplotlib绘制正余弦曲线图的实现
2021/02/22 Python
采用冷却技术的超自然舒适度:GhostBed床垫
2018/09/18 全球购物
Otticanet意大利:最顶尖的世界名牌眼镜, 能得到打折季的价格
2019/03/10 全球购物
英国最受欢迎的母婴精品品牌:JoJo Maman BéBé
2021/02/17 全球购物
UNIX文件系统分类
2014/11/11 面试题
会计专业自我评价
2014/02/12 职场文书
品牌转让协议书
2014/08/20 职场文书
2014教师党员自我评议(5篇)
2014/09/20 职场文书
个人租房协议书样本
2014/10/01 职场文书
离婚协议书范文2015
2015/01/26 职场文书
人身损害赔偿协议书
2016/03/22 职场文书