Java Spring boot microservice(jdk11)引发了hystrix.stream-exactor-endpoint异常
spring引导服务迁移到Java Spring boot microservice(jdk11)引发了hystrix.stream-exactor-endpoint异常,java,spring-boot,hystrix,java-11,Java,Spring Boot,Hystrix,Java 11,spring引导服务迁移到2.1.3.版本和jdk11后,会出现与hystrix流执行器相关的异常 异常为路径为[]的上下文中Servlet[hystrix.stream activator endpoint]的org.apache.catalina.core.ContainerBase.[Tomcat-1].[localhost].[/].[hystrix.stream activator endpoint]-Servlet.service(),抛出异常[] Spring启动版本:2.1.3
2.1.3.版本
和jdk11
后,会出现与hystrix流执行器相关的异常
异常为路径为[]的上下文中Servlet[hystrix.stream activator endpoint]的org.apache.catalina.core.ContainerBase.[Tomcat-1].[localhost].[/].[hystrix.stream activator endpoint]-Servlet.service(),抛出异常[]
Spring启动版本:2.1.3.0版本 Java版本:11 所有执行器端点都已公开:
management.endpoints.web.exposure.include=*
另外,hystrix.stream
endpoint实际上已启用,并提供了一个流。
然而,日志中仍然会出现异常
堆栈跟踪:
java.nio.BufferOverflowException
位于java.base/java.nio.DirectByteBuffer.put(DirectByteBuffer.java:410)
位于java.base/java.nio.DirectByteBuffer.put(DirectByteBuffer.java:389)
位于java.base/sun.nio.ch.IOUtil.write(IOUtil.java:74)
位于java.base/sun.nio.ch.IOUtil.write(IOUtil.java:50)
位于java.base/sun.nio.ch.SocketChannelImpl.write(SocketChannelImpl.java:466)
位于org.apache.tomcat.util.net.NioChannel.write(NioChannel.java:134)
位于org.apache.tomcat.util.net.NioBlockingSelector.write(NioBlockingSelector.java:105)
位于org.apache.tomcat.util.net.NioSelectorPool.write(NioSelectorPool.java:144)
位于org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper.doWrite(NioEndpoint.java:1223)
位于org.apache.tomcat.util.net.SocketWrapperBase.doWrite(SocketWrapperBase.java:743)
位于org.apache.tomcat.util.net.SocketWrapperBase.flushBlocking(SocketWrapperBase.java:696)
位于org.apache.tomcat.util.net.SocketWrapperBase.flush(SocketWrapperBase.java:686)
位于org.apache.coyote.http11.Http11OutputBuffer$SocketOutputBuffer.flush(Http11OutputBuffer.java:553)
位于org.apache.coyote.http11.filters.ChunkedOutputFilter.flush(ChunkedOutputFilter.java:157)
位于org.apache.coyote.http11.Http11OutputBuffer.flush(Http11OutputBuffer.java:216)
位于org.apache.coyote.http11.Http11Processor.flush(Http11Processor.java:1149)
位于org.apache.coyote.AbstractProcessor.action(AbstractProcessor.java:394)
位于org.apache.coyote.Response.action(Response.java:209)
位于org.apache.catalina.connector.OutputBuffer.doFlush(OutputBuffer.java:295)
位于org.apache.catalina.connector.OutputBuffer.flush(OutputBuffer.java:262)
位于org.apache.catalina.connector.CoyoteWriter.flush(CoyoteWriter.java:94)
位于org.apache.catalina.connector.CoyoteWriter.checkError(CoyoteWriter.java:119)
位于com.netflix.hystrix.contrib.sample.stream.hystrixsamplesservlet.handleRequest(hystrixsamplesservlet.java:165)
位于com.netflix.hystrix.contrib.sample.stream.hystrixsamplesservlet.doGet(hystrixsamplesservlet.java:74)
位于javax.servlet.http.HttpServlet.service(HttpServlet.java:634)
位于javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
位于org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
位于org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
位于org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:200)
位于org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
位于org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:490)
位于org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
位于org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
位于org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
位于org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
位于org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:408)
位于org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
位于org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:834)
位于org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1415)
位于org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
位于java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
位于java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
位于org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
位于java.base/java.lang.Thread.run(Thread.java:834)
还有一个类似的
java.lang.IllegalArgumentException:newPosition>limit:(3850>532)
位于java.base/java.nio.Buffer.createPositionException(Buffer.java:318)
位于java.base/java.nio.Buffer.position(Buffer.java:293)
位于java.base/java.nio.ByteBuffer.position(ByteBuffer.java:1086)
位于java.base/sun.nio.ch.IOUtil.write(IOUtil.java:82)
位于java.base/sun.nio.ch.IOUtil.write(IOUtil.java:50)
位于java.base/sun.nio.ch.SocketChannelImpl.write(SocketChannelImpl.java:466)
位于org.apache.tomcat.util.net.NioChannel.write(NioChannel.java:134)
位于org.apache.tomcat.util.net.NioBlockingSelector.write(NioBlockingSelector.java:105)
位于org.apache.tomcat.util.net.NioSelectorPool.write(NioSelectorPool.java:144)
位于org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper.doWrite(NioEndpoint.java:1223)
位于org.apache.tomcat.util.net.SocketWrapperBase.doWrite(SocketWrapperBase.java:743)
位于org.apache.tomcat.util.net.SocketWrapperBase.flushBlocking(SocketWrapperBase.java:696)
位于org.apache.tomcat.util.net.SocketWrapperBase.flush(SocketWrapperBase.java:686)
位于org.apache.coyote.http11.Http11OutputBuffer$SocketOutputBuffer.flush(Http11OutputBuffer.java:553)
位于org.apache.coyote.http11.filters.ChunkedOutputFilter.flush(ChunkedOutputFilter.java:157)
位于org.apache.coyote.http11.Http11OutputBuffer.flush(Http11OutputBuffer.java:216)
A.
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.3.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.robman</groupId>
<artifactId>demohystrix</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demohystrix</name>
<description>Demo project for Spring Boot</description>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>11</java.version>
<spring-cloud.version>Greenwich.SR3</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
management.endpoints.web.exposure.include=*
@SpringBootApplication
@EnableHystrix
@RestController
public class DemoHystrixApplication {
public static void main(String[] args) {
SpringApplication.run(DemoHystrixApplication.class, args);
}
@RequestMapping(value = "/")
@HystrixCommand(fallbackMethod = "fallback", commandProperties = {
@HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "1000")
})
public String hello() throws InterruptedException {
Thread.sleep(3000);
return "HELLO Hystrix";
}
private String fallback() {
return "Fallback";
}
}
<dependency>
<groupId>org.glassfish.jaxb</groupId>
<artifactId>jaxb-runtime</artifactId>
</dependency>