zoukankan      html  css  js  c++  java
  • Nginx 502错误总结

    http请求流程:一般情况下,提交动态请求的时候,nginx会直接把 请求转交给php-fpm,而php-fpm再分配php-cgi进程来处理相关的请求,之后再依次返回,最后由nginx把结果反馈给客户端浏览器。

    Nginx 502 Bad Gateway错误是FastCGI有问题,造成NGINX 502错误的可能性比较多。

    Nginx 502 Bad Gateway的含义是请求的PHP-CGI已经执行,但是由于某种原因(一般是读取资源的问题)没有执行完毕而导致PHP-CGI进程终止。

    解决办法

    遇到502问题,可以优先考虑按照以下两个步骤去解决。

    1、查看当前的PHP FastCGI进程数是否够用

    1. netstat -anpo | grep "php-cgi"| wc -l

    如果实际使用的“FastCGI进程数”接近预设的“FastCGI进程数”,那么,说明“FastCGI进程数”不够用,需要增大。

    2、部分PHP程序的执行时间超过了Nginx的等待时间

    可以适当增加nginx.conf配置文件中FastCGI的timeout时间,例如:

    1. ......
    2. http
    3. {
    4. ......
    5. fastcgi_connect_timeout 300;
    6. fastcgi_send_timeout 300;
    7. fastcgi_read_timeout 300;
    8. ......
    9. }
    10. ......

    php.ini中memory_limit设低了会出错,修改了php.ini的memory_limit为64M,重启nginx,发现好了,原来是PHP的内存不足了。

    如果这样修改了还解决不了问题,可以参考下面这些方案:

    3、max-children和max-requests

    一台服务器上运行着nginx php(fpm) xcache,访问量日均 300W pv左右

    最近经常会出现这样的情况: php页面打开很慢,cpu使用率突然降至很低,系统负载突然升至很高,查看网卡的流量,也会发现突然降到了很低。这种情况只持续数秒钟就恢复了

    检查php-fpm的日志文件发现了一些线索:

    1. Sep3008:32:23.289973[NOTICE] fpm_unix_init_main(), line 271: getrlimit(nofile): max:51200,cur:51200
    2. Sep3008:32:23.290212[NOTICE] fpm_sockets_init_main(), line 371:using inherited socket fd=10,127.0.0.1:9000
    3. Sep3008:32:23.290342[NOTICE] fpm_event_init_main(), line 109: libevent:using epoll
    4. Sep3008:32:23.296426[NOTICE] fpm_init(), line 47: fpm is running, pid 30587

    在这几句的前面,是1000多行的关闭children和开启children的日志

    原来,php-fpm有一个参数 max_requests,该参数指明了,每个children最多处理多少个请求后便会被关闭,默认的设置是500。因为php是把请求轮询给每个children,在大流量下,每个childre到达max_requests所用的时间都差不多,这样就造成所有的children基本上在同一时间被关闭。

    在这期间,nginx无法将php文件转交给php-fpm处理,所以cpu会降至很低(不用处理php,更不用执行sql),而负载会升至很高(关闭和开启children、nginx等待php-fpm),网卡流量也降至很低(nginx无法生成数据传输给客户端)

    解决问题很简单,增加children的数量,并且将 max_requests 设置未 0 或者一个比较大的值:

    打开 /usr/local/php/etc/php-fpm.conf

    调大以下两个参数(根据服务器实际情况,过大也不行)

    1. <valuename=”max_children”>5120</value>
    2. <valuename=”max_requests”>600</value>

    然后重启php-fpm。

    5、增加缓冲区容量大小

    将nginx的error log打开,发现“pstream sent too big header while reading response header from upstream”这样的错误提示。查阅了一下资料,大意是nginx缓冲区有一个bug造成的,我们网站的页面消耗占用缓冲区可能过大。参考老外写的修改办法增加了缓冲区容量大小设置,502问题彻底解决。后来系统管理员又对参数做了调整只保留了2个设置参数:client head buffer,fastcgi buffer size。

    6、request_terminate_timeout

    如果主要是在一些post或者数据库操作的时候出现502这种情况,而不是在静态页面操作中常见,那么可以查看一下php-fpm.conf设置中的一项:request_terminate_timeout

    这个值是max_execution_time,就是fast-cgi的执行脚本时间。

    0s为关闭,就是无限执行下去。(当时装的时候没仔细看就改了一个数字)

    发现,问题解决了,执行很长时间也不会出错了。

    优化fastcgi中,还可以改改这个值5s 看看效果。

    php-cgi进程数不够用、php执行时间长、或者是php-cgi进程死掉,都会出现502错误。

  • 相关阅读:
    Server Tomcat v8.0 Server at localhost failed to start.的解决方法
    使用quartz实现定时器功能
    使用SpringMVC自带的@Scheduled完成定时任务
    springMVC中不通过注解方式获取指定Service的javabean
    java set初始化问题
    一个粗糙的分页
    eclipse下maven springMVC 整合 mybatis
    联合分布(二):联合分布
    联合分布(一):什么是概率分布
    mysql:启动服务时遇到的问题
  • 原文地址:https://www.cnblogs.com/huqiang/p/5333826.html
Copyright © 2011-2022 走看看