Android通过Http协议POST请求异常(Connection reset by peer)

上周遇到了一个Connection reset by peer
网络连接问题,为此,我找遍了中英文的一些网站,搜遍了能找的每个角落,发现了出现这种状况的原理,该java异常在客户端和服务器端都有可能发生,引起该异常的原因有:

Connection reset by peer的常见原因:

1)服务器的并发连接数超过了其承载量,服务器会将其中一些连接关闭;

如果知道实际连接服务器的并发客户数没有超过服务器的承载量,则有可能是中了病毒或者木马,引起网络流量异常。可以使用netstat -an查看网络连接情况。

2)客户关掉了浏览器,而服务器还在给客户端发送数据;

3)浏览器端按了Stop;

这两种情况一般不会影响服务器。但是如果对异常信息没有特别处理,有可能在服务器的日志文件中,重复出现该异常,造成服务器日志文件过大,影响服务器的运行。可以对引起异常的部分,使用try...catch捕获该异常,然后不输出或者只输出一句提示信息,避免使用e.printStackTrace();输出全部异常信息。

4)防火墙的问题;

如果网络连接通过防火墙,而防火墙一般都会有超时的机制,在网络连接长时间不传输数据时,会关闭这个TCP的会话,关闭后在读写,就会导致异常。 如果关闭防火墙,解决了问题,需要重新配置防火墙,或者自己编写程序实现TCP的长连接。实现TCP的长连接,需要自己定义心跳协议,每隔一段时间,发送一次心跳协议,双方维持连接。

5)JSP的buffer问题。

JSP页面缺省缓存为8k,当JSP页面数据比较大的时候,有可能JSP没有完全传递给浏览器。这时可以适当调整buffer的大小。 <%@ page buffer="100k"%>

常见网络异常(转自http://www.cnblogs.com/kaixin110/archive/2008/04/11/1148671.html):

第1个异常是java.net.BindException:Address already in use: JVM_Bind。该异常发生在服务器端进行new ServerSocket

(port)(port是一个0,65536的整型值)操作时。异常的原因是以为与port一样的一个端口已经被启动,并进行监听。此时用

netstat –an命令,可以看到一个Listending状态的端口。只需要找一个没有被占用的端口就能解决这个问题。

第2个异常是java.net.ConnectException: Connection refused: connect。该异常发生在客户端进行 new Socket(ip, port)

操作时,该异常发生的原因是或者具有ip地址的机器不能找到(也就是说从当前机器不存在到指定ip路由),或者是该ip存在

,但找不到指定的端口进行监听。出现该问题,首先检查客户端的ip和port是否写错了,如果正确则从客户端ping一下服务器

看是否能 ping通,如果能ping通(服务服务器端把ping禁掉则需要另外的办法),则看在服务器端的监听指定端口的程序是否

启动,这个肯定能解决这个问题。

第3个异常是java.net.SocketException: Socket is closed,该异常在客户端和服务器均可能发生。异常的原因是己方主动关

闭了连接后(调用了Socket的close方法)再对网络连接进行读写操作。

第4个异常是java.net.SocketException: (Connection reset或者 Connect reset by peer:Socket write error)。该异常

在客户端和服务器端均有可能发生,引起该异常的原因有两个,第一个就是如果一端的Socket被关闭(或主动关闭或者因为异

常退出而引起的关闭),另一端仍发送数据,发送的第一个数据包引发该异常 (Connect reset by peer)。另一个是一端退出

,但退出时并未关闭该连接,另一端如果在从连接中读数据则抛出该异常(Connection reset)。简单的说就是在连接断开后

的读和写操作引起的。

第5个异常是java.net.SocketException: Broken pipe。该异常在客户端和服务器均有可能发生。在第4个异常的第一种情况中

(也就是抛出SocketExcepton:Connect reset by peer:Socket write error后),如果再继续写数据则抛出该异常。前两个异

常的解决方法是首先确保程序退出前关闭所有的网络连接,其次是要检测对方的关闭连接操作,发现对方关闭连接后自己也要

关闭该连接。

分析上面的几个原因之后,发现还是没有解决我所遇到的问题:

完整异常如下:

03-12 13:50:35.788: W/System.err(9801): java.net.SocketException: recvfrom failed: ECONNRESET (Connection reset by peer)

03-12 13:50:35.790: W/System.err(9801): at libcore.io.IoBridge.maybeThrowAfterRecvfrom(IoBridge.java:585)

03-12 13:50:35.790: W/System.err(9801): at libcore.io.IoBridge.recvfrom(IoBridge.java:548)

03-12 13:50:35.791: W/System.err(9801): at java.net.PlainSocketImpl.read(PlainSocketImpl.java:489)

03-12 13:50:35.792: W/System.err(9801): at java.net.PlainSocketImpl.access$000(PlainSocketImpl.java:46)

03-12 13:50:35.793: W/System.err(9801): at java.net.PlainSocketImpl$PlainSocketInputStream.read(PlainSocketImpl.java:240)

03-12 13:50:35.794: W/System.err(9801): at org.apache.http.impl.io.AbstractSessionInputBuffer.fillBuffer(AbstractSessionInputBuffer.java:103)

03-12 13:50:35.795: W/System.err(9801): at org.apache.http.impl.io.AbstractSessionInputBuffer.readLine(AbstractSessionInputBuffer.java:191)

03-12 13:50:35.796: W/System.err(9801): at org.apache.http.impl.conn.DefaultResponseParser.parseHead(DefaultResponseParser.java:82)

03-12 13:50:35.797: W/System.err(9801): at org.apache.http.impl.io.AbstractMessageParser.parse(AbstractMessageParser.java:174)

03-12 13:50:35.798: W/System.err(9801): at org.apache.http.impl.AbstractHttpClientConnection.receiveResponseHeader(AbstractHttpClientConnection.java:180)

03-12 13:50:35.799: W/System.err(9801): at org.apache.http.impl.conn.DefaultClientConnection.receiveResponseHeader(DefaultClientConnection.java:235)

03-12 13:50:35.800: W/System.err(9801): at org.apache.http.impl.conn.AbstractClientConnAdapter.receiveResponseHeader(AbstractClientConnAdapter.java:259)

03-12 13:50:35.801: W/System.err(9801): at org.apache.http.protocol.HttpRequestExecutor.doReceiveResponse(HttpRequestExecutor.java:279)

03-12 13:50:35.802: W/System.err(9801): at org.apache.http.protocol.HttpRequestExecutor.execute(HttpRequestExecutor.java:121)

03-12 13:50:35.803: W/System.err(9801): at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:431)

03-12 13:50:35.804: W/System.err(9801): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)

03-12 13:50:35.805: W/System.err(9801): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)

03-12 13:50:35.806: W/System.err(9801): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)

03-12 13:50:35.806: W/System.err(9801): at com.hb56.DriverReservation.android.net.MyHttpHelper.doRequestForEntity(MyHttpHelper.java:210)

03-12 13:50:35.807: W/System.err(9801): at com.hb56.DriverReservation.android.net.MyHttpHelper.doRequestForString(MyHttpHelper.java:103)

03-12 13:50:35.808: W/System.err(9801): at com.hb56.DriverReservation.android.net.MyHttpHelper.doRequestForString(MyHttpHelper.java:72)

03-12 13:50:35.809: W/System.err(9801): at com.hb56.DriverReservation.android.LoginActivity$MyAsyncTaskReqKeyHttp.doInBackground(LoginActivity.java:283)

03-12 13:50:35.810: W/System.err(9801): at com.hb56.DriverReservation.android.LoginActivity$MyAsyncTaskReqKeyHttp.doInBackground(LoginActivity.java:1)

03-12 13:50:35.812: W/System.err(9801): at android.os.AsyncTask$2.call(AsyncTask.java:264)

03-12 13:50:35.813: W/System.err(9801): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)

03-12 13:50:35.814: W/System.err(9801): at java.util.concurrent.FutureTask.run(FutureTask.java:137)

03-12 13:50:35.815: W/System.err(9801): at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:208)

03-12 13:50:35.816: W/System.err(9801): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)

03-12 13:50:35.817: W/System.err(9801): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)

03-12 13:50:35.819: W/System.err(9801): at java.lang.Thread.run(Thread.java:856)

03-12 13:50:35.821: W/System.err(9801): Caused by: libcore.io.ErrnoException: recvfrom failed: ECONNRESET (Connection reset by peer)

03-12 13:50:35.834: W/System.err(9801): at libcore.io.Posix.recvfromBytes(Native Method)

03-12 13:50:35.835: W/System.err(9801): at libcore.io.Posix.recvfrom(Posix.java:131)

03-12 13:50:35.836: W/System.err(9801): at libcore.io.BlockGuardOs.recvfrom(BlockGuardOs.java:164)

03-12 13:50:35.838: W/System.err(9801): at libcore.io.IoBridge.recvfrom(IoBridge.java:545)

03-12 13:50:35.838: W/System.err(9801): ... 28 more

后面通过用写了一下Java的项目工程,去调用服务器的API,并记录Log日志,抓取数据包文件分析,在服务器的API时有一个过滤器拦截了访问的API,然而在Android端异常的代码为:

HttpResponse httpResponse = httpClient.execute(request);//请求服务器链接

最后发现问题所在之处是服务器API的过滤器上,没有把所有的异常补货完全。

时间: 2024-12-30 03:21:21

Android通过Http协议POST请求异常(Connection reset by peer)的相关文章

老项目采用tomcat出现异常:Connection reset by peer: socket write error 异常解决方法

项目一段时间就出现异常,导致无法登陆系统,数据库无法连接上 异常信息如下: java.sql.SQLException: Io 异常: Connection reset by peer: socket write error at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:134) at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:179) a

Android中调用WebService抛出Connection reset by peer异常

最近在做的项目中用到了WebService,因为Android中没有提供直接调用WebService的Api,我就使用了 ksoap,但是在使用过程中遇到了一个奇怪的BUG: 请求一次WebService之后,什么都不做,静待1分钟之后,再次请求这个WebService时就会抛出以下异常: 06-17 15:11:07.869: W/System.err(10915): java.net.SocketException: sendto failed: ECONNRESET (Connection

文件上传时报Recv failure: Connection reset by peer异常解决

以前上传文件时报这个异常没这么在意,这次网络不好时总是报这个异常,导致文件上传失败,故特意说明一下,报个异常的原因还是很多的,今日只针对我当前遇上的问题进行记录一下. 背景:平时网络好的时候,我开启线程的上传和下载都没问题,网络慢的时候就出来这个异常 Recv failure: Connection reset by peer . 异常的原因有两点:1.网络非常慢时易导致该异常:2.线程多次重复请求网络服务造成的异常,因为上次启用的线程还没断开,所以该服务一直存在,导致再次进行上传请求时异常.

LR回放https协议脚本失败:[GENERAL_MSG_CAT_SSL_ERROR]connect to host &quot;XXX&quot; failed:[10054] Connection reset by peer [MsgId:MERR-27780]

最近做一个负载均衡项目的性能测试,使用LR录制脚本协议为https协议,回放脚本时出现报错: [GENERAL_MSG_CAT_SSL_ERROR]connect to host "XXX" failed:[10054] Connection reset by peer  [MsgId:MERR-27780] 如图: Loadrunner默认发送是通过sockets(将http转换为sockets)发送的,而sockets默认SSL的版本为SSL2和SSL3.HTTPS协议录制的脚本以

Jenkins Publish over SSH 异常:Connection reset by peer: socket write error

Jekins持续集成: 服务器时windows服务器: windows安装openssh服务: 安装包:https://github.com/PowerShell/Win32-OpenSSH/releases 开箱即用:步骤1 文件解压至C:\Program Files\OpenSSH 2 控制台cd至目录 3 执行powershell.exe -ExecutionPolicy Bypass -File install-sshd.ps1 启动服务ssh; 踩坑的地方:当时没有把文件放到C:\Pr

nginx错误分析 `104: Connection reset by peer`

故障描述 应用从虚拟机环境迁移到kubernetes环境中,有些应用不定时出现请求失败的情况,且应用没有记录任何日志,而在NGINX中记录502错误.我们查看了之前虚拟机中的访问情况,没有发现该问题. 基础信息 # 请求流程 client --> nginx(nginx-ingress-controller) --> tomcat(容器) # nginx版本 $ nginx -V nginx version: nginx/1.15.5 built by gcc 8.2.0 (Debian 8.

Connection reset by peer 的常见原因:

Connection reset by peer的常见原因: 1)服务器的并发连接数超过了其承载量,服务器会将其中一些连接关闭: 如果知道实际连接服务器的并发客户数没有超过服务器的承载量,则有可能是中了病毒或者木马,引起网络流量异常.可以使用netstat -an查看网络连接情况. 2)客户关掉了浏览器,而服务器还在给客户端发送数据: 3)浏览器端按了Stop: 这两种情况一般不会影响服务器.但是如果对异常信息没有特别处理,有可能在服务器的日志文件中,重复出现该异常,造成服务器日志文件过大,影响

Netty 中 IOException: Connection reset by peer 与 java.nio.channels.ClosedChannelException: null

最近发现系统中出现了很多 IOException: Connection reset by peer 与 ClosedChannelException: null 深入看了看代码, 做了些测试, 发现 Connection reset 会在客户端不知道 channel 被关闭的情况下, 触发了 eventloop 的 unsafe.read() 操作抛出 而 ClosedChannelException 一般是由 Netty 主动抛出的, 在 AbstractChannel 以及 SSLHand

Connection reset by peer问题分析

extremetable导出excel,弹出一个下载窗口,这时不点下载而点取消,则报下面的异常: ClientAbortException Caused by: java.net.SocketException: Connection reset by peer: socket write error 查了下TOMCAT的文档,解释如下: Wrap an IOException identifying it as being caused by an abort of a request by