最近开发时android时,发现一个bug,退后台的app,再回前台时,在onResume中调用api经常出现java.net.SocketTimeoutException。
当时的网络环境是可以的:有网络,服务器也正常。于是在网上找了一下,终于在这篇文章里找到了答案:https://github.com/square/okhttp/issues/3146和https://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))
这样的代码运行起来就没有经常出现这个异常了。