在日常的运维工程中经常遇到一些服务器的TCP连接过高,头疼不已。针对一些日常出现的问题,做一些总结,希望能抛砖引玉。

    现在网站大部分都使用nginx和tomcat,利用nginx高效的使用系统资源以及tomcat的处理事物高效来特点完成日常的网站运作。尝尝采用前端nginx进行转发后端tomcat进行处理的方式。

   很多时候会发现一些服务器本身的tcp过高,有些甚至过万。客户端那边反应请求过慢或者超时,服务器端显示调用接口超时等一些问题。

  其中有一种情况如下:

    $ netstat  -antp  | head

Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name

tcp        0      0 127.0.0.1:portA            127.0.0.1:portB           ESTABLISHED -

类似上面的连接很多,其中 Foreign Address 的端口是本地tomcat的java进行的端口 连接Local Address本地随机端口也就是说是前端nginx和后端tomcat端口之间连接过多导致。

那如何解决这个问题呢?

1、是否是后端java程序处理前端请求处理时间过慢导致长连接以及前端请求过多导致?

2、 是否可以把nginx的连接超时调小?如果调小之前遇到过499错误代码返回,如何解决?

3、连接过多是否可以理解请求过多导致,那添加机器进行扩容是否可以解决该问题?

4、最后也就是优化处理java程序,来解决 这个问题?

以上是我的个人想法,难免偏见,求指点。