如何在Spring Actuator端口上公开Hystrix Stream?

时间:2016-07-04 16:10:26

标签: spring spring-boot jetty hystrix

我在Spring Boot应用程序中使用Jetty嵌入式服务器。

为了处理请求,我提供了这样的自定义处理程序。

@Slf4j
@Configuration
@EnableWebMvc
@SpringBootApplication
public class Main {
    public static void main(String... args) {
        new SpringApplicationBuilder().sources(Main.class).run(args);
    }

    @Bean
    public EmbeddedServletContainerCustomizer customizer(JettyRequestHandler myCustomHandler) throws MalformedURLException {
        return new EmbeddedServletContainerCustomizer() {

            @Override
            public void customize(ConfigurableEmbeddedServletContainer container) {
                if (container instanceof JettyEmbeddedServletContainerFactory) {
                    customizeJetty((JettyEmbeddedServletContainerFactory) container);
                }
            }

            private void customizeJetty(JettyEmbeddedServletContainerFactory jetty) {
                jetty.addServerCustomizers((JettyServerCustomizer) server -> {
                    HandlerCollection handlerCollection = new HandlerCollection();
                    handlerCollection.setHandlers(new Handler[]{myCustomHandler, server.getHandler()});
                    server.setHandler(handlerCollection);
                });
            }
        };
    }
}

我正在侦听标准8080端口上的请求。我还将Spring Boot Actuator包括在我的项目中以获得一些生产端点(健康等)。它从另一个端口开始:8181

此外,我正在使用Hystrix进行电路断开。

我的问题是如何启用Hystrix Stream暴露在执行器端口上?

目前我设法只使用以下代码在标准端口8080上公开它:

@Bean
public ServletRegistrationBean hystrixStreamServlet(){
    return new ServletRegistrationBean(new HystrixMetricsStreamServlet(), "/hystrix.stream");
}

但我想将它暴露在另一个上,只有出于应用目的才有默认值。

这些是我的一些依赖:

compile 'com.netflix.hystrix:hystrix-core:1.5.3'
compile 'com.netflix.hystrix:hystrix-metrics-event-stream:1.5.3' 
compile 'org.springframework.boot:spring-boot-starter-actuator:1.3.5.RELEASE' 

我不想使用Spring Cloud,其中@EnableHystrix实际上为执行器端口提供了流。

1 个答案:

答案 0 :(得分:2)

实际上我做了@m-deinum提出的并且有效。我使用的是Spring Cloud Stack。

为了在执行器上实现Hystrix Stream,我添加了依赖性:

compile group: 'org.springframework.cloud', name: 'spring-cloud-starter', version: '1.1.1.RELEASE'          // spring cloud starter
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-hystrix', version: '1.1.3.RELEASE'  // spring cloud hystrix starter
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-ribbon', version: '1.1.3.RELEASE'   // spring ribbon starter

Main类上的注释:

@EnableCircuitBreaker
@SpringBootApplication
public class Main {
    public static void main(String... args) {
        new SpringApplicationBuilder().sources(Main.class).run(args);
    }
    // ...
}