zoukankan      html  css  js  c++  java
  • PHP出现502解决方案

    nginx 出现 502 有很多原因,但大部分原因可以归结为资源数量不够用,也就是说后端 php-fpm 处 理有问题,nginx 将正确的客户端请求发给了后端的 php-fpm 进程,但是因为 php-fpm 进程的问 题导致不能正确解析 php 代码,最终返回给了客户端 502 错误。

    服务器出现 502 的原因是连接超时我们向服务器发送请求由于服务器当前链接太多,导致服务器方 面无法给于正常的响应,产生此类报错。因此如果你服务器并发量非常大,那只能先增加机器,然后 按以下方式优化会取得更好效果;但如果你并发不大却出现 502,一般都可以归结为配置问题,脚本 超时问题。

    1. php.ini 的 memory_limit 过小

    (如果有个别 php 程序进程需要占用极大内存时这个必须注意)

    2. php-fpm.conf 中 max_children 或者 max_requests 设置不合理

    (设置过小会因为没有足够的 cgi 进程处理请求,设置过大会出现一会儿有响应正常,一会儿等很 久才有响应的情况,一般情况下 children 按 照内存计算,比如说 1G 设置 64,2G 128。这个根据 实际情况自行调整。另外查看当前的 PHP FastCGI 进程数是否够用的命令为:

    netstat  -anpo |grep php-cgi | wc -l   如果实际使用的“FastCGI 进程数;接近预设的;FastCGI 进 程数,那么,说明;FastCGI 进程数;不够用,需要增大。)

    3. 查看 nginx 错误日志

    发现 pstream sent too big header while reading response  headerfrom upstream ,则检查

    client head buffer,fastcgi buffer size 是否过小,可设置为 32K。

    4.  php 程序执行时间过长而超时,检查 nginx 和 fastcgi 中各种 timeout 设置。

    nginx: fastcgi_connect_timeout 300; fastcgi_send_timeout 300; fastcgi_read_timeout300; keepalive_timeout;

    php-fpm: request_terminate_timeout=300; php.ini: max_execution_time=300;

    不过 request_terminate_timeout 参数会直接杀掉 php 进程,然后重启 php 进程,这样前端 nginx 就会返回 104: Connection reset by peer,最好设成 request_terminate_timeout=0;但最重要的 是程序里要设置好超时,不要使用 php-fpm 的 request_terminate_timeout。

    5.php-fpm 参数 max_requests

    该参数指明了每个 children 最多处理多少个请求后便会被关闭。在大量处理请求下,如果该值设置 过小会导致 children 频繁的自杀和建立而浪费 大量时间,若所有的 children 差不多都在这个时候


    149

    6.调高调高 linux 内核打开文件数量

    可以使用这些命令(必须是 root 帐号)

    echo 'ulimit -HSn 65536'>> /etc/profile echo 'ulimit -HSn 65536'>> /etc/rc.local source /etc/profile

    7.缓存设置比较小 修改或增加配置到 nginx.conf proxy_buffer_size 64k; proxy_buffers 512k; proxy_busy_buffers_size 128k;

    8、自己遇到 502 的解决办法:

    调整增大 php 和 Nginx 的 backlog 数。

    以上差不多是比较常见的 502 的问题原因以及解决办法,其实解决问题的最好的方式还是自己去看

    nginx 和 fastcgi 的 errorlog。

    最后借用网上的万金油说法做个总结: php-cgi 进程数不够用、php 执行时间长、或者是 php-cgi

    进程死掉,都会出现 502 错误

  • 相关阅读:
    HDU 3466(01背包变种
    HDU 2639(01背包第K大)
    POJ 2184(01背包)(负体积)
    UVA 562(01背包)
    UVA 624(01背包记录路径)
    SQL总结二
    oracle--知识点汇总1
    时间日期----java
    字符串、数值----转换
    字符串反转----示例
  • 原文地址:https://www.cnblogs.com/fanweisheng/p/11333483.html
Copyright © 2011-2022 走看看