您的位置首页  科技产品

微信5.0.2(微信502错误是怎么解决

你常见的502错误如何排查呢

微信5.0.2(微信502错误是怎么解决

 

文章来自:开源社区作者:phper点击加入:PHP自学中心技术交流微信群商务合作: 请加微信(QQ):2230304070技术交流微信群我们在学习中单枪匹马,还不如一次短短的交流,你可以在别人吸取各种学习经验,

学习方法以及学习技巧,所以,学习与交流少不了一个圈子,提升你的学习技能,请点击加技术群:PHP自学中心交流③群记得备注:加群

视频教程分享1 Linux 工程师要知道的6类好习惯和23个教训2 做开发的不用Git,那就对不起自己啦3 别再小看PHP了,它因有性能强大的框架而不败4 带上你想要的Go语言与区块链学习流程图5 Python全栈+爬虫+高端自动化,系统的学习!

158元升级会员,获取网站全部视频教程网址:http://www.mano100.cn

精选文章正文如果你服务器用的是Nginx的话,在开发的过程中,偶尔会出现 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 -l3.FastCGI执行时间过长

根据实际情况调高以下参数值fastcgi_connect_timeout300; fastcgi_send_timeout300; fastcgi_read_timeout300;4.头部太大nginx和apache一样,有前端缓冲限制,可以调整缓冲参数

fastcgi_buffer_size32k; fastcgi_buffers832k;如果你使用的是nginx的负载均衡Proxying,调整proxy_buffer_size16k; proxy_buffers

416k;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 epollSep3008: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调大以下两个参数(根据服务器实际情况,过大也不行)

5120600然后重启php-fpm7、增加缓冲区容量大小将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错误系统的学习PHP关注本公众号:PHP自学中心,回复相应的关键词,领取以下视频教程1 PHP四大框架公众号里回复:20190229 。

2 微博登录、邮箱验证,短信验证公众号里回复:20190417 3 功能模块开发(微信,支付宝支付,扫码支付,小程序等)公众号里回复:20190403 4 Nginx提升特级课程公众号里回复:190401

5 NoSQL之Redis技术2016视频教程公众号里回复:190325以上是本文的全部内容,希望对大家的学习有帮助,也希望大家多多支持php自学中心

免责声明:本站所有信息均搜集自互联网,并不代表本站观点,本站不对其真实合法性负责。如有信息侵犯了您的权益,请告知,本站将立刻处理。联系QQ:1640731186