背景:一个系统的数据向另一个系统推送上千万的数据时,发生报错,报错如下:

 

 

错误信息Caused by: java.sql.SQLException: Io 异常: Connection reset by peer: socket write error 

错误原因:客户端与服务端的连接设置了超时时间,服务端那里的连接时间已经超时,而客户端不知道这个连接已经超时,接着访问,就会出现这个错误

解决:在Tomcat中server.xml中配置连接为长连接即可

配置如下:

http1.0 默认短连接,http1.1开始默认长连接

关于tomcat参数:

短连接配置:
<!-- tomcat 1w 并发测试 短连接-->
<Connector port="8080" protocol="HTTP/1.1" 
connectionTimeout="5000" 
maxThreads="10000"
minSpareThreads="100"
maxSpareThreads="10000"
acceptCount="5000"
URIEncoding="UTF-8"
redirectPort="8443" /> 


长连接配置:
<!-- bio keepAliveTimeout 长连接使用时间 ;maxKeepAliveRequests 长连接使用格式 ;(1,n) 表示连接(1,n)个请求就断开 ;-1 表示不限制 ,一般100-200;enableLookups 是否禁用dns查询, dns查询耗费网络 --> 
<Connector port="8080" protocol="HTTP/1.1" 
connectionTimeout="20000" 
URIEncoding="UTF-8"
redirectPort="8443"
maxKeepAliveRequests="-1"
keepAliveTimeout="15000"
enableLookups="false" />

注:如果需要长连接永久处于连接状态,需将connectionTimeout和keepAliveTimeout这两个参数去掉

posted on 2018-07-27 11:04  进_进  阅读(1071)  评论(1)    收藏  举报