okhttp经常出现SocketTimeoutException

举报
yd_221104950 发表于 2022/06/25 22:14:26 2022/06/25
【摘要】 最近开发时android时,发现一个bug,退后台的app,再回前台时,在onResume中调用api经常出现java.net.SocketTimeoutException。 当时的网络环境是可以的:有...

最近开发时android时,发现一个bug,退后台的app,再回前台时,在onResume中调用api经常出现java.net.SocketTimeoutException。

当时的网络环境是可以的:有网络,服务器也正常。于是在网上找了一下,终于在这篇文章里找到了答案:https://github.com/square/okhttp/issues/3146https://stackoverflow.com/questions/39219094/sockettimeoutexception-in-retrofit

一开始,我创建的okhttpclient的方式:

val clientBuilder = new OkHttpClient.Builder()
			.readTimeout(readTimeoutMillis, TimeUnit.MILLISECONDS)
			.writeTimeout(writeTimeoutMillis, TimeUnit.MILLISECONDS)
            .connectTimeout(connectTimeoutMillis, TimeUnit.MILLISECONDS)
            .retryOnConnectionFailure(true)

改善的方法就是加多下面两行:

.connectionPool(ConnectionPool(0, 1, TimeUnit.NANOSECONDS));
.protocols(listOf(Protocol.HTTP_1_1))

最后的代码如下

val clientBuilder = new OkHttpClient.Builder()
			.readTimeout(readTimeoutMillis, TimeUnit.MILLISECONDS)
			.writeTimeout(writeTimeoutMillis, TimeUnit.MILLISECONDS)
            .connectTimeout(connectTimeoutMillis, TimeUnit.MILLISECONDS)
            .retryOnConnectionFailure(true)
            .connectionPool(ConnectionPool(0, 1, TimeUnit.NANOSECONDS));
            .protocols(listOf(Protocol.HTTP_1_1))

这样的代码运行起来就没有经常出现这个异常了。

文章来源: blog.csdn.net,作者:WongKyunban,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/weixin_40763897/article/details/125456292

推荐

华为开发者空间发布

让每位开发者拥有一台云主机

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。