Connection reset by peer: socket write error错误分析及解决
问题描述:
java.net.SocketException: Connection reset by peer.
at jrockit.net.SocketNativeIO.write(IIIZ)I(Unknown Source)
at jrockit.net.SocketNativeIO.write(III)I(Unknown Source)
at jrockit.io.NativeIO.write(Ljava/io/FileDescriptor;II)I(Unknown Source
)
....
Connection reset by peer: socket write error错误分析:
常出现的Connection reset by peer: 原因可能是多方面的,不过更常见的原因是:
①:服务器的并发连接数超过了其承载量,服务器会将其中一些连接Down掉;
②:客户关掉了浏览器,而服务器还在给客户端发送数据;
③:浏览器端按了Stop
通常原因为:远程主机上对等方应用程序突然停止运行,或远程主机重新启动,或远程主机在远程方套接字上使用了“强制”关闭 (参见setsockopt(SO_LINGER))。另外,在一个或多个操作正在进行时,如果连接因“keep-alive”活动检测到一个失败而中 断,也可能导致此错误。此时,正在进行的操作以错误码WSAENETRESET失败返回,后续操作将失败返回错误码WSAECONNRESET。
但是如果频繁出现,就表示很 多客户端连接到Apache服务器的响应时间太长了,可能是网络的问题或者服务器性能问题。
网友分析:
要从一个被屏蔽的网站上下载一些东西,于是写了一个Servlet,将它传到了一台境外的服务器上.
让这台服务器去下载指定的资源,然后再回传给我.相当于一个代理吧.
JAVA code
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String url = "http://www.silk163.com"; //得到要下载的减肥资源的URL.
if (!StringUtils.isNullOrEmpty(url)) {
System.out.println(url);
URL u = new URL(url);
URLConnection conn = u.openConnection();
try { ///把响应头设置成一样的.
for (Map.Entry<String, List<String>> m : conn.getHeaderFields() .entrySet()) {
if (m != null && m.getKey() != null && m.getValue() != null && m.getValue().size() > 0) {
response.setHeader(m.getKey(), m.getValue().get(0)); } }
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
CommonLog.log.warn(e);
}
InputStream in = conn.getInputStream(); //从 connection得到inputstream OutputStream out = response.getOutputStream(); //得到向客户端的输出流
try {
IOUtils
.wrITe(conn.getInputStream(), response .getOutputStream()); //写数据.
} catch (Exception e) {
e.printStackTrace();
// TODO: handle exception
CommonLog.log.warn(e);
if (in != null) {
in.close();
}
if (out != null) {
out.close();
} } } }
IOUtils.wrITe()代码如下:
JAVA code
/** * 从input里面读取数据然后写入output,读完后自动关闭流。 * @param input inputStream * @param output outputStream * */ public static void write(InputStream input, OutputStream output) throws IOException { write(input,output,true); } /** * 自动从inputstream里面读数据,然后写到outputstream里面去。 * @param input inputstream * @param output outputstream * @param close 读完后是否自动关闭流。 * */ public static void write(InputStream input, OutputStream output,boolean close) throws IOException { byte[] b = new byte[1024]; int len = input.read(b); while (len != -1) { output.wrITe(b, 0, len); len = input.read(b); } output.flush(); if (close) { input.close(); output.close(); } }
将程序传到服务器上以后,在服务器上访问
http://localhost:8080/test/down?url=http://www.silk163.com/jianfei.zip
可以下载成功.
但是当远程访问的时候,就会出现
JAVA.NET.SocketException: Connection reset by peer: socket wrITe error
假设服务器IP是2.2.2.2吧.
访问
http://2.2.2.2:8080/test/down?url=http://www.xxx.com/z.zip
就会出现上面的那个错误.
注意,我并没有关闭浏览器或者按停止按钮.只要一打上那个地址就会出错.
错误发生在:
JAVA code
output.wrITe(b, 0, len);//执行这行代码的时候.
具体的错误信息如下:
JAVA code
ClientAbortException: java.net.SocketException: Connection reset by peer: socket write error at org.apache.catalina.connector.OutputBuffer.realWriteBytes(OutputBuffer.java:366) at org.apache.tomcat.util.buf.ByteChunk.flushBuffer(ByteChunk.java:432) at org.apache.tomcat.util.buf.ByteChunk.append(ByteChunk.java:347) at org.apache.catalina.connector.OutputBuffer.writeBytes(OutputBuffer.java:392) at org.apache.catalina.connector.OutputBuffer.write(OutputBuffer.java:381) at org.apache.catalina.connector.CoyoteOutputStream.write(CoyoteOutputStream.java:89) at com.joejoe.utils.IOUtils.write(IOUtils.java:62) at com.joejoe.utils.IOUtils.wrITe(IOUtils.java:48) at com.tqsoft.wdys.other.getMegavideo.doGet(getMegavideo.java:79) at javax.servlet.http.HttpServlet.service(HttpServlet.java:627) at javax.servlet.http.HttpServlet.service(HttpServlet.java:729) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:269) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188) at com.joejoe.utils.WEB.CharSetFilter.doFilter(CharSetFilter.java:39) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:215) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:213) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:172) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:117) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:108) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:174) at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:875) at org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BASEProtocol.java:665) at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:528) at org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:81) at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:689) at java.lang.Thread.run(Unknown Source)Caused by: java.net.SocketException: Connection reset by peer: socket write error at java.net.SocketOutputStream.socketWrite0(Native Method) at java.net.SocketOutputStream.socketWrITe(Unknown Source) at JAVA.NET.SocketOutputStream.write(Unknown Source) at org.apache.coyote.http11.InternalOutputBuffer.realWriteBytes(InternalOutputBuffer.java:750) at org.apache.tomcat.util.buf.ByteChunk.flushBuffer(ByteChunk.java:432) at org.apache.tomcat.util.buf.ByteChunk.append(ByteChunk.java:347) at org.apache.coyote.http11.InternalOutputBuffer$OutputStreamOutputBuffer.doWrite(InternalOutputBuffer.java:773) at org.apache.coyote.http11.filters.IdentityOutputFilter.doWrite(IdentityOutputFilter.java:118) at org.apache.coyote.http11.InternalOutputBuffer.doWrite(InternalOutputBuffer.java:583) at org.apache.coyote.Response.doWrite(Response.java:560) at org.apache.catalina.connector.OutputBuffer.realWrITeBytes(OutputBuffer.JAVA:361) ... 27 more
请问如何解决.谢谢.
编 程论坛 5 个网友回答: 说是这原因
存在的连接被远程主机强制关闭。通常原因为:远程主机上对等方应用程序突然停止运行,或远程主机重新启动,或远程主机在远程方套接字上使用了“强制”关闭 (参见setsockopt(SO_LINGER))。另外,在一个或多个操作正在进行时,如果连接因“keep-alive”活动检测到一个失败而中 断,也可能导致此错误。此时,正在进行的操作以错误码WSAENETRESET失败返回,后续操作将失败返回错误码WSAECONNRESET。 .
编 程论坛 6 个网友回答: ClientAbortException: JAVA.NET.SocketException: Connection reset by peer: socket wrITe error的原因是由于处理http连接时,正在输出内容时,用户关闭了IE,会出现一个"ClientAbortException",属于I/O处理 中出现的一个异常,应用服务器应该会捕捉。
Connection reset by peer的原因:
经常出现的Connection reset by peer: 原因可能是多方面的,不过更常见的原因是:
①:服务器的并发连接数超过了其承载量,服务器会将其中一些连接Down掉;
②:客户关掉了浏览器,而服务器还在给客户端发送数据;
③:浏览器端按了Stop
很多人都说是客户端造成的,没有办法控制,是个比较郁闷的问题。