码迷,mamicode.com
首页 > Web开发 > 详细

502 Bad Gateway(PHP的角度来分析)

时间:2016-08-08 12:11:36      阅读:165      评论:0      收藏:0      [点我收藏+]

标签:

第一点:   request_terminate_timeout引起的资源问题
    request_terminate_timeout的值如果设置为0或者过长的时间,可能会引起file_get_contents的资源问题。如果file_get_contents请求的远程资源如果反应过慢,file_get_contents就会一直卡在那里不会超时。
我们知道php.ini 里面max_execution_time 可以设置 PHP 脚本的最大执行时间,但是,在 php-cgi(php-fpm) 中,该参数不会起效。真正能够控制 PHP 脚本最大执行时间的是 php-fpm.conf 配置文件中的request_terminate_timeout参数。 request_terminate_timeout默认值为 0 秒,也就是说,PHP 脚本会一直执行下去。这样,当所有的 php-cgi 进程都卡在 file_get_contents() 函数时,
这台 Nginx+PHP 的 WebServer 已经无法再处理新的 PHP 请求了,Nginx 将给用户返回“502 Bad Gateway”。修改该参数,设置一个 PHP 脚本最大执行时间是必要的,但是,治标不治本。例如改成 30s,如果发生 file_get_contents() 获取网页内容较慢的情况,
这就意味着 150 个 php-cgi 进程,每秒钟只能处理 5 个请求,WebServer 同样很难避免”502 Bad Gateway”。解决办法是request_terminate_timeout设置为10s或者一个合理的值,或者给file_get_contents加一个超时参数。 $ctx = stream_context_create(array( ‘http‘ => array( ‘timeout‘ => 10 //设置一个超时时间,单位为秒 ) )); file_get_contents($str, 0, $ctx); 第二点:max_requests参数配置不当,可能会引起间歇性502错误: pm.max_requests = 1000; 设置每个子进程重生之前服务的请求数. 对于可能存在内存泄漏的第三方模块来说是非常有用的. 如果设置为 ’0′ 则一直接受请求. 等同于 PHP_FCGI_MAX_REQUESTS 环境变量. 默认值: 0. 这段配置的意思是,当一个 PHP-CGI 进程处理的请求数累积到 1000 个后,自动重启该进程。 但是为什么要重启进程呢? 一般在项目中,我们多多少少都会用到一些 PHP 的第三方库,这些第三方库经常存在内存泄漏问题,如果不定期重启 PHP-CGI 进程,势必造成内存使用量不断增长。因此 PHP-FPM 作为 PHP-CGI 的管理器,提供了这么一项监控功能,
对请求达到指定次数的 PHP-CGI 进程进行重启,保证内存使用量不增长。
正是因为这个机制,在高并发的站点中,经常导致 502 错误,我猜测原因是 PHP-FPM 对从 NGINX 过来的请求队列没处理好。不过我目前用的还是 PHP 5.3.2,不知道在 PHP 5.3.3 中是否还存在这个问题。 目前我们的解决方法是,把这个值尽量设置大些,尽可能减少 PHP-CGI 重新 SPAWN(产卵) 的次数,同时也能提高总体性能。在我们自己实际的生产环境中发现,内存泄漏并不明显,因此我们将这个值设置得非常大(204800)。大家要根据自己的实际情况设置这个值,不能盲目地加大。 话说回来,这套机制目的只为保证 PHP-CGI 不过分地占用内存,为何不通过检测内存的方式来处理呢?我非常认同高春辉所说的,通过设置进程的峰值内在占用量来重启 PHP-CGI 进程,会是更好的一个解决方案。

综上,针对fpm重启的观点,本人认为可以利用 在fpm中进程池的概览,我们可以设置多个进程池;

[www]
user = www
group = www
listen = 127.0.0.1:9001
pm = dynamic
pm.max_children = 500
pm.start_servers = 200
pm.min_spare_servers = 100
pm.max_spare_servers = 300


[www]
user = www
group = www
listen = 127.0.0.1:9000
pm = dynamic
pm.max_children = 500
pm.start_servers = 200
pm.min_spare_servers = 100
pm.max_spare_servers = 300





nginx 配置

机器A nginx.conf配置

#在http 区域中增加:

upstream backend{
      server  127.0.0.1:9000 weight=1;
      server  127.0.0.1:9001 weight=2;
      keepalive 3072;
}

 

#在server 内如下配置

 location ~ .*\.php
 {
            fastcgi_pass backend;
            fastcgi_index index.php;
            include fastcgi.conf;
  }

 

502 Bad Gateway(PHP的角度来分析)

标签:

原文地址:http://www.cnblogs.com/sixiong/p/5748380.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!