HTTP连接池调用微信接口:443 failed to respond

一、调用微信接口时,经常出现错误:

java.lang.RuntimeException: org.apache.http.NoHttpResponseException: api.weixin.qq.com:443 failed to respond

接口:https://api.weixin.qq.com/sns/jscode2session

 

二、原因:

1. 微信服务端的http keepalive时长是20s

2. 使用一个连接发送http请求完成后,假设下次使用这个连接是在20s之后,微信端其实已经抛弃了这个连接

3. 如果继续使用这个连接发送请求,就会报443的错误,微信服务端主动抛弃链接

 

三、解决

1. HTTP客户端连接设置超时时间(socketTimeout),不超过20s,例如15s

2. 检查空闲连接的机制setValidateAfterInactivity,也设置成15s

3. 清理过期连接的时间evictIdleConnections,也设置成15s

4. 加上重试机制setRetryStrategy

 

 

参考:

https://juejin.cn/post/6865277186438496269

 

posted @ 2021-01-19 14:10  牧云文仔  阅读(6725)  评论(1编辑  收藏  举报