继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

PHP 出现 502 解决方案

一只甜甜圈
关注TA
已关注
手记 205
粉丝 55
获赞 117

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

服务器出现502的原因是连接超时我们向服务器发送请求由于服务器当前链接太多,导致服务器方面无法给于正常的响应,产生此类报错。因此如果你服务器并发量非常大,那只能先增加机器,然后按以下方式优化会取得更好效果;但如果你并发不大却出现502,一般都可以归结为配置问题,脚本超时问题。

1.  php.ini的memory_limit 过小

(如果有个别php程序进程需要占用极大内存时这个必须注意)

 

2.  php-fpm.conf 中max_children或者max_requests  设置不合理

(设置过小会因为没有足够的cgi进程处理请求,设置过大会出现一会儿有响应正常,一会儿等很久才有响应的情况,一般情况下children按 照内存计算,比如说1G设置64,2G 128。这个根据实际情况自行调整。另外查看当前的PHP FastCGI进程数是否够用的命令为:

netstat  -anpo |grep php-cgi | wc -l   如果实际使用的“FastCGI进程数;接近预设的;FastCGI进程数,那么,说明;FastCGI进程数;不够用,需要增大。)

 

3.  查看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_timeout300;

keepalive_timeout;

php-fpm:

request_terminate_timeout=300;

php.ini:

max_execution_time=300;


不过request_terminate_timeout参数会直接杀掉php进程,然后重启php进程,这样前端nginx就会返回104: Connection reset by peer,最好设成request_terminate_timeout=0;但最重要的是程序里要设置好超时,不要使用php-fpm的request_terminate_timeout。


5.php-fpm参数max_requests 

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

 

6.调高调高linux内核打开文件数量

可以使用这些命令(必须是root帐号)

echo 'ulimit -HSn 65536'>> /etc/profile

echo 'ulimit -HSn 65536'>> /etc/rc.local

source /etc/profile

 

7.缓存设置比较小

修改或增加配置到nginx.conf

proxy_buffer_size 64k;
proxy_buffers  512k;
proxy_busy_buffers_size 128k;

 

8、自己遇到502的解决办法:

调整增大php 和Nginx 的backlog数,且nginx和php的backlog数相同。如:backlog=1000000


 

以上差不多是比较常见的502的问题原因以及解决办法,其实解决问题的最好的方式还是自己去看nginx和fastcgi的errorlog。

最后借用网上的万金油说法做个总结: php-cgi进程数不够用、php执行时间长、或者是php-cgi进程死掉,都会出现502错误。

 

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP