现在的位置: 首页 > web前端 > 正文

如何解决ConnectionError

2020年07月16日 web前端 ⁄ 共 1069字 ⁄ 字号 评论关闭

  在使用HttpClient调用后台resetful服务时,“Connectionreset”是一个比较常见的问题,有同学跟我私信说被这个问题困扰很久了,今天就来分析下,希望能帮到大家。


  如何解决ConnectionError


  例如我们线上的网关日志就会抛该错误:


  155739_bWFp_1990220.png


  从日志中可以看到是Socket套接字在read数据时抛出了该错误。


  导致“Connectionreset”的原因是服务器端因为某种原因关闭了Connection,而客户端依然在读写数据,此时服务器会返回复位标志“RST”,然后此时客户端就会提示“java.net.SocketException:Connectionreset”。


  可能有同学对复位标志“RST”还不太了解,这里简单解释一下:


  TCP建立连接时需要三次握手,在释放连接需要四次挥手;例如三次握手的过程如下:


  第一次握手:客户端发送syn包(syn=j)到服务器,并进入SYN_SENT状态,等待服务器确认;


  第二次握手:服务器收到syn包,并会确认客户的SYN(ack=j+1),同时自己也发送一个SYN包(syn=k),即SYN+ACK包,此时服务器进入SYN_RECV状态;


  第三次握手:客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK(ack=k+1),此包发送完毕,客户端和服务器进入ESTABLISHED(TCP连接成功)状态,完成三次握手。


  可以看到握手时会在客户端和服务器之间传递一些TCP头信息,比如ACK标志、SYN标志以及挥手时的FIN标志等。


  除了以上这些常见的标志头信息,还有另外一些标志头信息,比如推标志PSH、复位标志RST等。其中复位标志RST的作用就是“复位相应的TCP连接”。


  Connectionreset异常的一种解决办法


  最近压测时,服务端系统出现了“Connectionreset”的异常,原因是服务器关闭了Connection[调用了Socket.close()方法]。当检查了应用中没有显示关闭的链接的代码后,调系统内核的参数后压测再无报错:


  a.进入:vim/etc/sysctl.conf


  b.添加:net.core.somaxconn=2048该参数默认为128,根据实际场景调大


  c.执行sysctl-p命令


  d.(可选)查看sysctl-a|grepsomaxconn


  总之,Connectionreset异常给大家简单的介绍了一些,希望大家多看看。

抱歉!评论已关闭.