墨色风雨
502的问题有很多种情况,主要的问题就是nginx->php这一层出现问题,可能是并发问题,也可能是PHP处理能力问题,还有可能是code代码的问题.你说的127.0.0.1比较多是很正常的,估计是因为你的nginx调用php使用的是ip:port的方式,还有mysql也会是走的127.0.0.1,所以你应该用端口来区分.另外你说数量比较多,也不会全是ESTABLIST,如果你了解TCP协议就会知道,会有哪些状态.你可以查看下各个状态的量.netstat-n|awk'/^tcp/{++S[$NF]}END{for(ainS)printa,S[a]}'如果TIMEWAIT的数量太多,当然是可以做一些优化的.net.core.somaxconn=4096net.ipv4.tcp_max_syn_backlog=8192net.ipv4.tcp_syn_retries=5net.ipv4.tcp_synack_retries=5net.ipv4.tcp_abort_on_overflow=0net.ipv4.tcp_tw_reuse=1net.ipv4.tcp_tw_recycle=1net.ipv4.tcp_timestamps=1net.ipv4.tcp_syncookies=1net.ipv4.tcp_max_tw_buckets=90000net.ipv4.tcp_fin_timeout=30net.ipv4.ip_local_port_range=1000065000net.ipv4.tcp_keepalive_time=1200如果担心并发能力的问题,可以查看下ulimit还有nginx的并发控制.其实如果你的访问量(PV)没有太多变化,但是导致了502我想你应该多查看下php的日志.另外很常见的一个可能性是因为某个PHP程序hang住,导致你之后的PHP进程全部堵塞出现处理能力不够,这个可以查看你每一个请求的处理时间.还有限制php进程处理时间,减少Backlog的数量,但并不一定Max_children开得越大越好,像2G的还是开小些吧,32够了.尤其是在出现502的时候一定要多观察PHP的状态,是有defunct,还是有CPU或者内存占用很大的进程.都是可以发现问题的.要具体问题具体分析了.下面看下我实验的502情况(结构说明:Nginx(proxy)-->Nginx+PHP表格中说的nginx和PHP都是非proxy):操作过程返回时间返回码nginx进程不存在立马502服务器死机>proxy_connect_timeout502Nginx存在,fpm不存在立马502nginx存在,fastcgi执行超时>fastcgi_read_timeout504fpmbacklog队列满立马502fpm主动断开>request_terminate_timeout502PS:你的标题应该改改,应该是"网站频繁出现502,怀疑是127.0.0.1连接太多",把现象先描述出来.