常见的Nginx 502 Bad Gateway解决办法如下:

Nginx 502错误情况1:

网站的访问量大,而php-cgi的进程数偏少。

针对这种情况的502错误,只需增加php-cgi的进程数。具体就是修改/usr/local/php/etc/php-fpm.conf 文件,将其中的max_children值适当增加。这个数据要依据你的VPS或独立服务器的配置进行设置。一般一个php-cgi进程占20M内存,你可以自己计算下,适量增多。

/usr/local/php/sbin/php-fpm restart 然后重启一下.

Nginx 502错误情况2:

CPU占用率、内存占用率非常高,遭到CC攻击.

解决方法请参考:LinuxVPS简单解决CC攻击

Nginx 502错误情况3:

CPU占用率不高,内存溢出。

检查一下网站程序有没有问题?一般小偷站点常常会出现内存溢出。

检查一下/var/log/目录下的日志,看看是不是有人爆破SSH和FTP端口?

SSH、FTP遭到穷举也会占用大量内存。是的话改掉SSH端口和FTP端口即可

将网上找到的一些和502 Bad Gateway错误有关的问题和排查方法列一下,先从FastCGI配置入手:

1.查看FastCGI进程是否已经启动

NGINX 502错误的含义是sock、端口没被监听造成的。我们先检查fastcgi是否在运行

2.检查系统Fastcgi进程运行情况

除了第一种情况,fastcgi进程数不够用、php执行时间长、或者是php-cgi进程死掉也可能造成nginx的502错误
运行以下命令判断是否接近FastCGI进程,如果fastcgi进程数接近配置文件中设置的数值,表明worker进程数设置太少

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

3.FastCGI执行时间过长

根据实际情况调高以下参数值

fastcgi_connect_timeout 300; fastcgi_send_timeout 300; fastcgi_read_timeout 300;

4.头部太大

nginx和apache一样,有前端缓冲限制,可以调整缓冲参数

fastcgi_buffer_size 32k;
fastcgi_buffers 8 32k;

如果你使用的是nginx的负载均衡Proxying,调整

proxy_buffer_size 16k; proxy_buffers 4 16k;

5.https转发配置错误

正确的配置方法

server_name www.jb51.net; location /myproj/repos
{ set $fixed_destination $http_destination; if ( $http_destination ~* ^https(.*)$ ){ set $fixed_destination http$1;} proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header Destination $fixed_destination; proxy_pass http://subversion_hosts;
}

6 max-children和max-requests

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

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

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

Sep3008:32:23.289973[NOTICE] fpm_unix_init_main(), line 271: getrlimit(nofile): max:51200,cur:51200
Sep3008:32:23.290212[NOTICE] fpm_sockets_init_main(), line 371:using inherited socket fd=10,“127.0.0.1:9000″
Sep3008:32:23.290342[NOTICE] fpm_event_init_main(), line 109: libevent:using epoll
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

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

<valuename=”max_children”>5120</value>
<valuename=”max_requests”>600</value>

然后重启php-fpm。

7、增加缓冲区容量大小

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

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

Nginx 502的解决方法相关推荐

  1. Linux系统下Jsp验证码显示不出来, nginx 返回500 解决方法

    Linux系统下Jsp验证码显示不出来, nginx 返回500 解决方法 tomcat日志 localhost.1949-09-15.log 报错信息 1949-09-15 9:13:34 org. ...

  2. 重启nginx后丢失nginx.pid的解决方法(转)

    重启nginx后丢失nginx.pid的解决方法(转) 参考文章: (1)重启nginx后丢失nginx.pid的解决方法(转) (2)https://www.cnblogs.com/zl1991/p ...

  3. nginx 启动报错 “/var/run/nginx/nginx.pid“ failed” 解决方法

    nginx 启动报错 "/var/run/nginx/nginx.pid" failed" 解决方法 参考文章: (1)nginx 启动报错 "/var/run ...

  4. Nginx遇到无法创建或打开nginx.pid的解决方法

    nginx: [error] CreateFile() "E:\nginx-1.13.5/logs/nginx.pid" failed nginx: [error] Open() ...

  5. nginx 403错误解决方法

    nginx 403错误解决方法 如果报了directory index of "/data/web/yafwx/public/moban/" is forbidden 看nginx ...

  6. php网站调试出现的简单问题,调试php时网站出现502的解决方法

    这是第二次遇到该问题了,上次解决后因为没有记录,结果这次遇到后又得重新查找解决方法.记忆力严重减退了啊,还是要保持边学边记录的习惯 网站在正常运行时是没有问题的,但是在使用xdebug进行远程调试时, ...

  7. Nginx中木马解决方法

    今天偶然看到网上一篇处理Nginx网站中木马的解决方法,觉得还可以,于是转载下来作为将来不备之需. 导读: 服务器突然负载比平常高出了50%,经过长时间分析发现原来是黑客利用nginx的一个漏洞,通过 ...

  8. Nginx重启时丢失nginx.pid文件解决方法nginx: [emerg] open() “/var/run/nginx/nginx.pid“ failed (2: No such fi

    nginx: [emerg] open() "/var/run/nginx/nginx.pid" failed (2: No such file or directory) 不要在 ...

  9. 重启nginx后丢失nginx.pid的解决方法

    在使用的阿里云服务器上,进程性的 nginx -s stop后再次启动nginx -s reload ,总是会报错误nginx: [error] open() "/alidata/serve ...

最新文章

  1. 前端技巧-JS元编程ES6 symbol公开符号
  2. POS消费机C#例子代码
  3. python table_用python解析word文件(二):table
  4. SQL Server商业智能中ODS表和Dim表必须有的字段
  5. 深入浅出VMware——虚拟机暂停后生成的文件
  6. Elmedia Player Pro Mac使用技巧,Elmedia键盘快捷键
  7. javascript高级程序设计读书笔记——事件总结
  8. python中pass的使用_Python pass详细介绍及实例代码
  9. 主题插件WordPress淘宝客ZZDGM主题Upanel插件使用补充
  10. 爬虫教程( 6 ) --- 爬虫 进阶、扩展
  11. MySQL数据增加语句
  12. GAMP|Visual Studio 2019环境下配置GAMP
  13. 基于微信小程序视频点播系统 开题报告
  14. 8080端口号被占用的解决方法
  15. 四种超实用的超级记忆法-数字定桩法,借助语句定桩法,标题定桩法,记忆宫殿法
  16. linux怎么查看pid对应的进程,linux如何查看某个pid的进程?
  17. STM32+GM65二维码识别模块
  18. plupload上传文件 php,jQuery Plupload上传插件的使用方法详解
  19. filco的pin码_Filco圣手二代双模蓝牙机械键盘连接方法
  20. 苹果计算机重装系统步骤,苹果mac系统重装_苹果电脑Mac系统重装方法

热门文章

  1. 计算机软件专业可以考哪些证书
  2. 企业转型升级,务必抓住“企业上云”政策红利
  3. C#编程学习:正则表达式的使用
  4. 手势检测及手掌质心的运动轨迹(opencv)
  5. 【网页支付】支付宝内置浏览器调用支付功能
  6. AI时代的追星逐浪,中国科技的奋发自强
  7. pycharm创建虚拟环境后突然出现invalid SDK标识
  8. C语言经典面试题及面试宝典
  9. uni-app第三方登录
  10. SysML实践指南第二版(中文翻译:刘亚龙)第16章 蒸馏器案例