httpClient4.3.5超时设置

     这两天使用httpclient4.3.5(好像httpclient每个版本差别挺大的)访问一个https的服务,发现跑一段时间后有连接在createLayeredSocket的时候卡住,并且一直不超时释放,线程调用栈:

"Thread-12" daemon prio=10 tid=0x00002aaab488a000 nid=0x4b02 runnable [0x0000000042712000]

   java.lang.Thread.State: RUNNABLE

        at java.net.SocketInputStream.socketRead0(Native Method)

        at java.net.SocketInputStream.read(SocketInputStream.java:129)

        at com.sun.net.ssl.internal.ssl.InputRecord.readFully(InputRecord.java:293)

        at com.sun.net.ssl.internal.ssl.InputRecord.read(InputRecord.java:331)

        at com.sun.net.ssl.internal.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:830)

        - locked <0x000000078309d398> (a java.lang.Object)

        at com.sun.net.ssl.internal.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1170)

        - locked <0x000000078309d4a0> (a java.lang.Object)

        at com.sun.net.ssl.internal.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1197)

        at com.sun.net.ssl.internal.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1181)

        at org.apache.http.conn.ssl.SSLConnectionSocketFactory.createLayeredSocket(SSLConnectionSocketFactory.java:275)

        at org.apache.http.conn.ssl.SSLConnectionSocketFactory.connectSocket(SSLConnectionSocketFactory.java:254)

        at org.apache.http.impl.conn.HttpClientConnectionOperator.connect(HttpClientConnectionOperator.java:123)

        at org.apache.http.impl.conn.PoolingHttpClientConnectionManager.connect(PoolingHttpClientConnectionManager.java:318)

        at org.apache.http.impl.execchain.MainClientExec.establishRoute(MainClientExec.java:363)

 

     google了一圈,httpclient有个几个超时时间需要设置,少设置了PoolingHttpClientConnectionManager中DefaultSocketConfig的超时时间。

在使用连接池的情况下,访问https请求。httpClient超时的设置包括两个位置:

1 httppost.setConfig(requestConfig); 通过执行的http请求设置RequestConfig。

RequestConfig包括setConnectionRequestTimeout分配等待连接池分配的超时时间、setConnectTimeout建立网络连接的超时时间、setSocketTimeout 通讯过程中的超时时间。

2 PoolingHttpClientConnectionManager.setDefaultSocketConfig;连接管理器设置设置默认socket 超时时间,SocketConfig.Builder.setSoTimeout方法。

执行设置了RequestConfig的https请求时,处理过程如下:



 

与超时时间相关的位置:

A 从连接池获取连接,最长的等待时间,使用RequestConfig. getConnectionRequestTimeout。

B 创建socket对象,使用SocketConfig . getSoTimeout设置socket的soTimeout.

C  socket建立网络连接,使用RequestConfig.getConnectTimeout作为发起连接的超时时间。

D createLayeredSocket完成SSL握手处理,使用socket的超时时间(就是B设置的SocketConfig . getSoTimeout)。

E 使用RequestConfig.getSocketTimeout设置分配的Socket的soTimeout。后续处理过程就用这个超时时间了。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值