WebClient工具调用HTTP接口报错远程主机断开连接
WebClient工具调用HTTP接口报错远程主机断开连接
- 现象
- 原因
- 解决
现象
使用WebClient
工具发送http请求,调用其他模块服务时,控制台报错远程主机断开连接
(出现在,短时间内发送多次http请求,比如:一个接口内连续调用多次/for循环内调用多次发送http请求)
原因
运维同事抓包发现,是发送http请求时与对应服务建立了一个连接
(我这边和服务器都没有对这个连接进行处理断开),WebClient第二次请求时,还是用了上一次的连接
,这个时候对应服务模块断开了连接,也就表现为快速请求多次,第二次请求会出现“远程主机断开连接”
解决
请求的模块不支持长连接,那就将工具配置为短连接。
(http Client和web Client等工具都是默认的长连接,且比较合理的方式也应该是长连接+连接池)
全局配置webClient工具
@Configuration
public class WebClientConfig {@Beanpublic WebClient webClient(WebClient.Builder builder) {// 创建短连接配置,ConnectionProvider.newConnection()创建新连接HttpClient httpClient = HttpClient.create(ConnectionProvider.newConnection())// 禁用TCP keep-alive,使用短连接.option(io.netty.channel.ChannelOption.SO_KEEPALIVE, false)// 设置连接超时时间.option(io.netty.channel.ChannelOption.CONNECT_TIMEOUT_MILLIS, 5000)// 设置响应超时时间.responseTimeout(Duration.ofSeconds(30))// 设置读写超时处理器.doOnConnected(conn -> conn.addHandlerLast(new io.netty.handler.timeout.ReadTimeoutHandler(30)).addHandlerLast(new io.netty.handler.timeout.WriteTimeoutHandler(30)));// 配置WebClient使用短连接HttpClientreturn builder.clientConnector(new ReactorClientHttpConnector(httpClient)).build();}
}