java 常见超时异常原因


 

 

一、java.net.SocketTimeoutException: failed to connect to/103.83.45.229(port 443)from/192.168.1.124(port 49054)after 10000ms

可能出现的原因:

(1)在真机测试的时候,手机连接的数据流量,而不是公司的局域网. 把手机网络连接设置为有局域网就可以了.

(2)设置的请求建立连接超时时间过短,没有连接到服务器;   增加connectTimeout连接的时间; 

(3)设置的请求建立连接超时时间过短,会抛出java.net.SocketException: connetct time out的异常。

 

二、java.net.SocketTimeoutException: SSL handshake timed out:

   (1)设置的readTimeout过短,没有读取到资源;

 

三、java.io.IOException: unexpected end of stream on okhttp3.Address@XXXX

增加关闭连接即可

.addHeader("Connection", "close")

 

 

 

 

ConnectTimeout
指的是建立连接所用的时间,适用于网络状况正常的情况下,两端连接所用的时间。
在java中,网络状况正常的情况下,例如使用HttpClient或者HttpURLConnetion连接时设置参数connectTimeout=5000即5秒,如果连接用时超过5秒就是抛出java.net.SocketException: connetct time out的异常。


ReadTimeout
指的是建立连接后从服务器读取到可用资源所用的时间。
在这里我们可以这样理解ReadTimeout:正常情况下,当我们发出请求时可以收到请求的结果,也就是页面上展示的内容,但是当网络状况很差的时候,就会出现页面上无法展示出内容的情况。另外当我们使用爬虫或者其他全自动的程序时,无法判断当前的网络状况是否良好,此时就有了ReadTimeout的用武之地了,通过设置ReadTimeout参数,例:ReadTimeout=5000,超过5秒没有读取到内容时,就认为此次读取不到内容并抛出Java.net.SocketException: read time out的异常。

 

根据上面关于ConnectTimeout和ReadTimeout的描述,在我们使用需要设置这两项参数的服务或程序时,应该对两项参数一起设置。
一般而言两项参数的数值可以设置成一样的,但根据笔者个人经验,可以把ReadTimeout设置的长一点,ConnectTimeout可以相对比较短,这是源于我们的网络状况一般较为稳定,连接时很少出现问题,但是读取时因为数据下载时的网络波动,出状况的可能性更大一些。

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM