在调用doGetConnection()时,我的httpclient实现偶尔会抛出异常。但是,我有以下超时设置
_moHttpClient.setHttpConnectionFactoryTimeout(30000);
它看起来几乎像我的超时没有被拿起。是否有其他我需要设置超时以确保不再发生此行为
答案 0 :(得分:10)
你被抛出什么例外?
不要忘记你有两次超时来更改/检查。来自HttpConnectionParams
setConnectionTimeout()
setSoTimeout()
因此您可以控制等待连接服务器的时间,以及在超时之前对套接字执行的操作时间。
答案 1 :(得分:7)
HttpConnectionManagerParams cmparams = new HttpConnectionManagerParams();
cmparams.setSoTimeout(10000);
cmparams.setTcpNoDelay(true);
HttpConnectionManager manager = new SimpleHttpConnectionManager();
manager.setParams(cmparams);
params = new HttpClientParams();
params.setSoTimeout(5000);
client = new HttpClient(params, manager);
我想知道为什么我有两个不同的SoTimeout设置。也许我试图找出哪一个实际上是活跃的,因为我在使用它时遇到了与你相同的问题。
以上是我们现在的实时代码,但我不能说它是否有效,因为它是正确的,或者因为天意对我微笑(而另一端通常是可用的)。
答案 2 :(得分:4)
cmparams.setSoTimeout(10000);
默认情况下,这个适用于所有HttpClient。
params.setSoTimeout(5000);
这个是针对特定的httpclient。