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