<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0">
<channel>
<title><![CDATA[向东博客 专注WEB应用 构架之美 --- 构架之美，在于尽态极妍 | 应用之美，在于药到病除]]></title> 
<link>http://jackxiang.com/index.php</link> 
<description><![CDATA[赢在IT，Playin' with IT,Focus on Killer Application,Marketing Meets Technology.]]></description> 
<language>zh-cn</language> 
<copyright><![CDATA[向东博客 专注WEB应用 构架之美 --- 构架之美，在于尽态极妍 | 应用之美，在于药到病除]]></copyright>
<item>
<link>http://jackxiang.com/post//</link>
<title><![CDATA[nginx 502 Bad Gateway 错误解决办法,Nginx日志分析502状态awk简单统计了解。]]></title> 
<author>jack &lt;xdy108@126.com&gt;</author>
<category><![CDATA[Php/Js/Shell/Go]]></category>
<pubDate>Fri, 26 Sep 2014 05:39:51 +0000</pubDate> 
<guid>http://jackxiang.com/post//</guid> 
<description>
<![CDATA[ 
	背景：php-fpm一般来说是够用，难免不够用，一是怎么样看，二是怎么样判断是否真够用，博主用了一个命令：netstat -anpo &#124; grep &quot;php-cgi&quot; &#124; wc -l 去和自己配置php-fpm.conf作对比，再者是对nginx出现各种错误都出现502揽在自己身上了，于其说nginx是为了安全，还不如说是也给排查问题增加了难度，再就是超时等，nginx有nginx的超时，php有php配置的超时，双方都是一个相互关联的问题，这些都是对于lnmp架构里经常遇到的问题。<br/><br/>统计Nginx日志里有502的行数有一个大体的了解，如下：<br/> cat a.txt <br/>183.60.235.59 - - [31/Jan/2015:00:00:06 +0800] &quot;GET /forum/0/index.html HTTP/1.1&quot; 302 <br/>183.60.235.59 - - [31/Jan/2015:00:00:06 +0800] &quot;GET /forum/0/index.html HTTP/1.1&quot; 302 <br/>183.60.235.59 - - [31/Jan/2015:00:00:06 +0800] &quot;GET /forum/0/index.html HTTP/1.1&quot; 502 <br/>183.60.235.59 - - [31/Jan/2015:00:00:06 +0800] &quot;GET /forum/0/index.html HTTP/1.1&quot; 302 <br/>183.60.235.59 - - [31/Jan/2015:00:00:06 +0800] &quot;GET /forum/0/index.html HTTP/1.1&quot; 302 <br/>183.60.235.59 - - [31/Jan/2015:00:00:06 +0800] &quot;GET /forum/0/index.html HTTP/1.1&quot; 302 <br/><br/>cat a.txt &#124;awk &#039;&#123;print &quot;line:&quot;NR &quot; status:&quot;$9&#125;&#039;&#124;grep 502<br/>line:3 status:502<br/><br/>——————————————————————————————————————————————<br/>Nginx 502的触发条件<br/><br/>　　502错误最通常的出现情况就是后端主机当机。在upstream配置里有这么一项配置：proxy_next_upstream，这个配置指定了 nginx在从一个后端主机取数据遇到何种错误时会转到下一个后端主机，里头写上的就是会出现502的所有情况拉，默认是error timeout。error就是当机、断线之类的，timeout就是读取堵塞超时，比较容易理解。我一般是全写上的：<br/><br/>proxy_next_upstream error timeout invalid_header http_500 http_503;　　不过现在可能我要去掉http_500这一项了，http_500指定后端返回500错误时会转一个主机，后端的jsp出错的话，本来会打印一堆 stacktrace的错误信息，现在被502取代了。但公司的程序员可不这么认为，他们认定是nginx出现了错误，我实在没空跟他们解释502的原理 了……<br/><br/>503错误就可以保留，因为后端通常是apache resin，如果apache死机就是error，但resin死机，仅仅是503，所以还是有必要保留的。<br/><br/>解决办法<br/><br/>遇到502问题，可以优先考虑按照以下两个步骤去解决。<br/><br/>1、查看当前的PHP FastCGI进程数是否够用：<br/><br/><br/>复制代码 代码如下:<br/><br/>netstat -anpo &#124; grep &quot;php-cgi&quot; &#124; wc -l<br/><br/><br/>如果实际使用的“FastCGI进程数”接近预设的“FastCGI进程数”，那么，说明“FastCGI进程数”不够用，需要增大。<br/><br/>2、部分PHP程序的执行时间超过了Nginx的等待时间，可以适当增加nginx.conf配置文件中FastCGI的timeout时间，例如：<br/><br/><br/>复制代码 代码如下:<br/><br/> http&nbsp;&nbsp;&#123;&nbsp;&nbsp;fastcgi_connect_timeout 300;&nbsp;&nbsp;fastcgi_send_timeout 300;&nbsp;&nbsp;fastcgi_read_timeout 300;&nbsp;&nbsp;......&nbsp;&nbsp;&#125;&nbsp;&nbsp;......<br/><br/><br/>php.ini中memory_limit设低了会出错，修改了php.ini的memory_limit为64M，重启nginx，发现好了，原来是PHP的内存不足了。<br/><br/>　　如果这样修改了还解决不了问题，可以参考下面这些方案：<br/><br/>一、max-children和max-requests<br/><br/>　　一台服务器上运行着nginx php(fpm) xcache，访问量日均 300W pv左右。<br/><br/>　　最近经常会出现这样的情况：php页面打开很慢，cpu使用率突然降至很低，系统负载突然升至很高，查看网卡的流量，也会发现突然降到了很低。这种情况只持续数秒钟就恢复了。<br/><br/>　　检查php-fpm的日志文件发现了一些线索。<br/><br/><br/>复制代码 代码如下:<br/><br/>Sep 30 08:32:23.289973 [NOTICE] fpm_unix_init_main(), line 271: getrlimit(nofile): max:51200, cur:51200&nbsp;&nbsp;Sep 30 08:32:23.290212 [NOTICE] fpm_sockets_init_main(), line 371: using inherited socket fd=10, “127.0.0.1:9000″&nbsp;&nbsp;Sep 30 08:32:23.290342 [NOTICE] fpm_event_init_main(), line 109: libevent: using epoll&nbsp;&nbsp;Sep 30 08:32:23.296426 [NOTICE] fpm_init(), line 47: fpm is running, pid 30587　<br/><br/><br/>在这几句的前面，是1000多行的关闭children和开启children的日志。<br/><br/>　　原来，php-fpm有一个参数 max_requests，该参数指明了，每个children最多处理多少个请求后便会被关闭，默认的设置是500。因为php是把请求轮询给每个 children，在大流量下，每个childre到达max_requests所用的时间都差不多，这样就造成所有的children基本上在同一时间 被关闭。<br/><br/>　　在这期间，nginx无法将php文件转交给php-fpm处理，所以cpu会降至很低(不用处理php，更不用执行sql)，而负载会升至很高(关闭和开启children、nginx等待php-fpm)，网卡流量也降至很低(nginx无法生成数据传输给客户端)<br/><br/>　　解决问题很简单，增加children的数量，并且将 max_requests 设置未 0 或者一个比较大的值：<br/><br/>　　打开 /usr/local/php/etc/php-fpm.conf调大以下两个参数(根据服务器实际情况，过大也不行）<br/><br/><br/>复制代码 代码如下:<br/><br/>&lt;value&gt;5120&lt;/value&gt;&lt;value&gt;600&lt;/value&gt;　　<br/><br/><br/>然后重启php-fpm。<br/><br/>二、增加缓冲区容量大小<br/><br/>　　将nginx的error log打开，发现“pstream sent too big header while reading response header from upstream”这样的错误提示。查阅了一下资料，大意是nginx缓冲区有一个bug造成的,我们网站的页面消耗占用缓冲区可能过大。参考老外写的修 改办法增加了缓冲区容量大小设置，502问题彻底解决。后来系统管理员又对参数做了调整只保留了2个设置参数：client head buffer，fastcgi buffer size。<br/><br/>三、request_terminate_timeout<br/><br/>　　如果主要是在一些post或者数据库操作的时候出现502这种情况，而不是在静态页面操作中常见，那么可以查看一下php-fpm.conf设置中的一项：<br/><br/>request_terminate_timeout<br/><br/>这个值是max_execution_time，就是fast-cgi的执行脚本时间。<br/><br/>0s<br/><br/>0s为关闭，就是无限执行下去。（当时装的时候没仔细看就改了一个数字）问题解决了，执行很长时间也不会出错了。优化fastcgi中，还可以改改这个值5s 看看效果。<br/><br/>php-cgi进程数不够用、php执行时间长、或者是php-cgi进程死掉，都会出现502错误。Nginx 502 Bad Gateway错误的解决办法2<br/><br/>今天，我的VPS频繁提示Nginx 502 Bad Gateway错误了，重启了VPS解决之后又出现，很烦。有点想不通，前两天网站达到了1290的访问量都没有出什么问题，怎么这次就出现了502 Bad Gateway？郁闷啊！！！在搜索了很久，终于找到了不少相关的答案，希望修改之后不会再出现这个错误了。唉，既然在网上找了那么久的答案，那当然得把有用的东西记录下，免得我下次再去谷歌~<br/><br/>由于我是采用了LNMP一键安装包 ，出了问题肯定要先到官方论坛去搜索下了，真好，官方有个这样的置顶帖，大家先瞧瞧。<br/><br/>LNMP一键安装包官方的：<br/><br/>第一种原因：目前lnmp一键安装包比较多的问题就是502 Bad Gateway，大部分情况下原因是在安装php前，脚本中某些lib包可能没有安装上，造成php没有编译安装成功。解决办法：可以尝试根据lnmp一键安装包中的脚本手动安装一下，看看是什么错误导致的。<br/><br/>第二种原因：<br/><br/>在php.ini里，eaccelerator配置项一定要放在Zend Optimizer配置之前，否则也可能引起502 Bad Gateway<br/><br/>第三种原因：<br/><br/>在安装好使用过程中出现502问题，一般是因为默认php-cgi进程是5个，可能因为phpcgi进程不够用而造成502，需要修改/usr/local/php/etc/php-fpm.conf 将其中的max_children值适当增加。<br/><br/>第四种原因：<br/><br/>php执行超时，修改/usr/local/php/etc/php.ini 将max_execution_time 改为300<br/><br/>第五种原因：<br/><br/>磁盘空间不足，如mysql日志占用大量空间<br/><br/>第六种原因：<br/><br/>查看php-cgi进程是否在运行<br/><br/>也有网友给出了另外的解决办法：<br/><br/>Nginx 502 Bad Gateway的含义是请求的PHP-CGI已经执行，但是由于某种原因（一般是读取资源的问题）没有执行完毕而导致PHP-CGI进程终止，一般来说Nginx 502 Bad Gateway和php-fpm.conf的设置有关。<br/><br/>php-fpm.conf有两个至关重要的参数，一个是max_children，另一个是request_terminate_timeout，但是这个值不是通用的，而是需要自己计算的。在安装好使用过程中出现502问题，一般是因为默认php-cgi进程是5个，可能因为phpcgi进程不够用而造成502，需要修改/usr/local/php/etc/php-fpm.conf 将其中的max_children值适当增加。<br/><br/>计算的方式如下：<br/><br/>如果你的服务器性能足够好，且宽带资源足够充足，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左右。<br/><br/>按照官方的答案，排查了相关的可能，并结合了网友的答案，得出了下面的解决办法。<br/><br/>1、查看php fastcgi的进程数（max_children值）<br/><br/>代码：netstat -anpo &#124; grep “php-cgi” &#124; wc -l<br/><br/>5（假如显示5）<br/><br/>2、查看当前进程<br/><br/>代码：top观察fastcgi进程数,假如使用的进程数等于或高于5个，说明需要增加（根据你机器实际状况而定）<br/><br/>3、调整/usr/local/php/etc/php-fpm.conf 的相关设置<br/><br/>&lt;value name=”max_children”&gt;10&lt;/value&gt;&lt;value name=”request_terminate_timeout”&gt;60s&lt;/value&gt;max_children最多10个进程，按照每个进程20MB内存，最多200MB。request_terminate_timeout执行的时间为60秒，也就是1分钟。<br/><br/><br/>来自：http://jingyan.baidu.com/article/eb9f7b6dacaac3869364e88f.html<br/>参考二：http://lxy.me/nginx-502-bad-gateway-error-causes-and-solutions.html
]]>
</description>
</item><item>
<link>http://jackxiang.com/post//#blogcomment</link>
<title><![CDATA[[评论] nginx 502 Bad Gateway 错误解决办法,Nginx日志分析502状态awk简单统计了解。]]></title> 
<author> &lt;user@domain.com&gt;</author>
<category><![CDATA[评论]]></category>
<pubDate>Thu, 01 Jan 1970 00:00:00 +0000</pubDate> 
<guid>http://jackxiang.com/post//#blogcomment</guid> 
<description>
<![CDATA[ 
	
]]>
</description>
</item>
</channel>
</rss>