小知识:Nginx php如何解决502 Bad Gateway错误

在Web服务器中有很多先进的技术,Nginx php就是其中的一个,接下来我们就看看在Nginx 中的相关问题解决,希望大家有所收获。Nginx php中配置php fastcgi组解决莫名其妙的502 Bad Gateway错误

%小知识:Nginx php如何解决502 Bad Gateway错误-猿站网-插图

一般Nginx php都采用这样的方式:

location ~ \.php$ {   proxy_pass http://localhost:9000;  

fastcgi_param SCRIPT_FILENAME /data/_hongdou$fastcgi_

script_name;  
include fastcgi_params;  

这个方式只能连接到一组spawn-fcgi开启的fastcgi,在服务器负载稍高时常常出现502 bad gateway错误。

起先怀疑这是php-cgi的进程开得太少,增加后仍然有反映时常有错,偶然间发现php-cgi会报出这样的错误:

zend_mm_heap corrupted 

看来是php-cgi在执行某些代码时有问题,以致于该线程中止。

在服务器上可能还会看到php-cgi进程在不断变少,估计是出现错误的php-cgi的进程自动退出了。

php的问题总是不太容易能解决,所以在Nginx php方面想想办法,Nginx的好处是它总是能爆出一些稀奇古怪的做法出来。在Nginx的proxy中,规避莫名其妙错误的办法无非是proxy到一个upstream的服务器组中,然后配置proxy_next_upstream,让Nginx遇到某种错误码时,自动跳到下一个后端上。这样,应用服务器即使不稳定,但是在Nginx后面就变成了稳定服务。想到Nginx的fastcgi和proxy是一路东西,所以proxy能用的经验,移植到fastcgi也能跑得起来。照着这个思路,用spawn-fcgi多开同样一组php进程,所不同的仅仅是端口:

spawn-fcgi -a 127.0.0.1 -p 9000 -u nobody -f php-cgi -C 100   spawn-fcgi -a 127.0.0.1 -p 9001 -u nobody -f php-cgi -C 100 

然后把fastcgi的这段配置改成用upstream的方式:

upstream backend {   server 127.0.0.1:9000;   server 127.0.0.1:9001;   }   location ~ \.php$ {   proxy_pass http://backend;  

fastcgi_param SCRIPT_FILENAME /data/_hongdou$fastcgi_

script_name;  
include fastcgi_params;  

检查配置结果正确,能跑起来;同时在服务器上netstat -n|grep 9000和grep 9001都有记录,证明连接无误;在前台查阅页面,一切运行正常。这个配置是最简单的配置,既然能连接上upstream,那么很显然upstream的一些东西都可以拿来用,比如ip_hash、weight、max_fails等。这样的配置在单机下不知能不能共享session,没有测试,如果有问题,可以加上ip_hash,或者配置php把session存进memcached中。然后就是fastcgi_next_upstream的配置,Nginx wiki中没有介绍到这个配置,查了一下,在Nginx php的CHANGES中有提到,而且出生年月是和proxy_next_upstream一样的。

既然如此,那就照proxy_next_upstream一样配吧。一般按默认的值error timeout就可以工作,因为php出现502错误的异常是返回的500错误,所以我把fastcgi_next_upstream定为:fastcgi_next_upstream error timeout invalid_header http_500;通过这个配置,就可以基本杜绝任何时常性的500错误,出问题的几率会变小很多,如果客户反映仍然激烈,那么就多增加几组fastcgi进程。以上配置能够杜绝由于php所引起的“莫名其妙”的时常性的502错误,同时可使Nginx搭配php比从前方式更为强悍。假如Nginx还是返回502错误,那这次就一定是出现服务器挂掉或其它严重问题的了。

声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。
建站知识

小知识:Linux下指定源ip进行ping操作的方法

2023-3-25 2:45:51

建站知识

小知识:Linux 系统使用私钥登录的教程详解

2023-3-25 2:54:17

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索