我使用 SpringRestTemplate对另一个服务(NodeJS 服务)进行休息调用。间歇性地出现连接重置错误。相同的代码在 JDK 8 和 Spring boot 2.0.1 上运行良好,在升级到Amazon Corretto JDK 11 和 Spring boot 2.1.5 后,开始看到这个问题。
Caused by: javax.net.ssl.SSLException: Connection reset
at java.base/sun.security.ssl.Alert.createSSLException(Alert.java:127)
at java.base/sun.security.ssl.TransportContext.fatal(TransportContext.java:321)
at java.base/sun.security.ssl.TransportContext.fatal(TransportContext.java:264)
at java.base/sun.security.ssl.TransportContext.fatal(TransportContext.java:259)
at java.base/sun.security.ssl.SSLSocketImpl.handleException(SSLSocketImpl.java:1314)
Run Code Online (Sandbox Code Playgroud)
org.springframework.web.client.RestTemplate.doExecute(RestTemplate.java:735)
... 143 common frames omitted
Suppressed: java.net.SocketException: Broken pipe (Write failed)
at java.base/java.net.SocketOutputStream.socketWrite0(Native Method)
at java.base/java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:110)
at java.base/java.net.SocketOutputStream.write(SocketOutputStream.java:150)
Run Code Online (Sandbox Code Playgroud)
-Dhttps.protocols=TLSv1,TLSv1.1,TLSv1.2SocketFactory这些协议设置为RestTemplate.socketTimeout重置客户端。仍然没有运气。
#代码:#
HttpHeaders headers = new HttpHeaders(); …Run Code Online (Sandbox Code Playgroud)