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错误。

  • 相关阅读:
    工作中遇到的java 内存溢出,问题排查
    java线上内存溢出问题排查步骤
    性能测试-java内存溢出问题排查
    164 01 Android 零基础入门 03 Java常用工具类01 Java异常 04 使用try…catch…finally实现异常处理 04 终止finally执行的方法
    163 01 Android 零基础入门 03 Java常用工具类01 Java异常 04 使用try…catch…finally实现异常处理 03 使用多重catch结构处理异常
    162 01 Android 零基础入门 03 Java常用工具类01 Java异常 04 使用try…catch…finally实现异常处理 02 使用try-catch结构处理异常
    161 01 Android 零基础入门 03 Java常用工具类01 Java异常 04 使用try…catch…finally实现异常处理 01 try-catch-finally简介
    160 01 Android 零基础入门 03 Java常用工具类01 Java异常 03 异常处理简介 01 异常处理分类
    159 01 Android 零基础入门 03 Java常用工具类01 Java异常 02 异常概述 02 异常分类
    158 01 Android 零基础入门 03 Java常用工具类01 Java异常 02 异常概述 01 什么是异常?
  • 原文地址:https://www.cnblogs.com/huqiang/p/5333826.html
Copyright © 2011-2022 走看看