diff --git a/spring-web/src/main/java/org/springframework/http/client/Netty4ClientHttpRequestFactory.java b/spring-web/src/main/java/org/springframework/http/client/Netty4ClientHttpRequestFactory.java index 33456ef938a..f5a059c245f 100644 --- a/spring-web/src/main/java/org/springframework/http/client/Netty4ClientHttpRequestFactory.java +++ b/spring-web/src/main/java/org/springframework/http/client/Netty4ClientHttpRequestFactory.java @@ -48,6 +48,9 @@ import org.springframework.util.Assert; *
Allows to use a pre-configured {@link EventLoopGroup} instance: useful for * sharing across multiple clients. * + *
Note that this implementation consistently closes the HTTP connection on each
+ * request.
+ *
* @author Arjen Poutsma
* @author Rossen Stoyanchev
* @author Brian Clozel
@@ -78,8 +81,6 @@ public class Netty4ClientHttpRequestFactory implements ClientHttpRequestFactory,
private volatile Bootstrap bootstrap;
- private volatile Bootstrap sslBootstrap;
-
/**
* Create a new {@code Netty4ClientHttpRequestFactory} with a default
@@ -177,20 +178,17 @@ public class Netty4ClientHttpRequestFactory implements ClientHttpRequestFactory,
private Bootstrap getBootstrap(URI uri) {
boolean isSecure = (uri.getPort() == 443 || "https".equalsIgnoreCase(uri.getScheme()));
if (isSecure) {
- if (this.sslBootstrap == null) {
- this.sslBootstrap = buildBootstrap(true);
- }
- return this.sslBootstrap;
+ return buildBootstrap(uri, true);
}
else {
if (this.bootstrap == null) {
- this.bootstrap = buildBootstrap(false);
+ this.bootstrap = buildBootstrap(uri, false);
}
return this.bootstrap;
}
}
- private Bootstrap buildBootstrap(boolean isSecure) {
+ private Bootstrap buildBootstrap(URI uri, boolean isSecure) {
Bootstrap bootstrap = new Bootstrap();
bootstrap.group(this.eventLoopGroup).channel(NioSocketChannel.class)
.handler(new ChannelInitializer