Hystrix 仪表板不工作

Hystrix Dashboard not working

我在 springboot 应用程序中使用 REST 服务。我正在使用 Hystrix 来启用指标。因此,我在版本 7 的 tomcat 服务器中部署了 hystrix 仪表板 war。我能够打开页面 http://localhost:8080/hystrix-dashboard/。添加流 url 并单击“监控流”按钮后,它会将我带到监控页面,在那里我只能看到消息“无法连接到命令 metrix 流”。当我查看 hystrix 控制台时,我反复看到以下消息。请帮助我!

2016-10-04 07:23:28 INFO  com.netflix.turbine.discovery.InstanceObservable:289 [InstanceObservable] [run]: Hosts up:1, hosts down: 0
2016-10-04 07:23:28 INFO  com.netflix.turbine.monitor.instance.InstanceMonitor:460 [InstanceMonitor] [getNextStatsData]: no more data from c
onnection to 138.12.51.246
2016-10-04 07:23:28 INFO  com.netflix.turbine.monitor.instance.InstanceMonitor:477 [InstanceMonitor] [retryHostConnection]: Re-initing host
connection: 138.12.51.246 default
2016-10-04 07:23:30 INFO  com.netflix.turbine.monitor.instance.InstanceMonitor:460 [InstanceMonitor] [getNextStatsData]: no more data from c
onnection to 138.12.51.246
2016-10-04 07:23:30 INFO  com.netflix.turbine.monitor.instance.InstanceMonitor:477 [InstanceMonitor] [retryHostConnection]: Re-initing host
connection: 138.12.51.246 default
2016-10-04 07:23:31 INFO  com.netflix.turbine.monitor.instance.InstanceMonitor:460 [InstanceMonitor] [getNextStatsData]: no more data from c
onnection to 138.12.51.246
2016-10-04 07:23:31 INFO  com.netflix.turbine.monitor.instance.InstanceMonitor:477 [InstanceMonitor] [retryHostConnection]: Re-initing host
connection: 138.12.51.246 default
2016-10-04 07:23:32 INFO  com.netflix.turbine.monitor.instance.InstanceMonitor:460 [InstanceMonitor] [getNextStatsData]: no more data from c
onnection to 138.12.51.246
2016-10-04 07:23:32 INFO  com.netflix.turbine.monitor.instance.InstanceMonitor:477 [InstanceMonitor] [retryHostConnection]: Re-initing host
connection: 138.12.51.246 default
2016-10-04 07:23:33 INFO  com.netflix.turbine.monitor.instance.InstanceMonitor:460 [InstanceMonitor] [getNextStatsData]: no more data from c
onnection to 138.12.51.246
2016-10-04 07:23:33 INFO  com.netflix.turbine.monitor.instance.InstanceMonitor:477 [InstanceMonitor] [retryHostConnection]: Re-initing host
connection: 138.12.51.246 default
2016-10-04 07:23:35 INFO  com.netflix.turbine.monitor.instance.InstanceMonitor:460 [InstanceMonitor] [getNextStatsData]: no more data from c
onnection to 138.12.51.246
2016-10-04 07:23:35 INFO  com.netflix.turbine.monitor.instance.InstanceMonitor:477 [InstanceMonitor] [retryHostConnection]: Re-initing host
connection: 138.12.51.246 default
2016-10-04 07:23:36 INFO 

找到答案。我们需要在响应 header 中添加 MIME 类型为 text/event-stream。我在此处编写的修复程序专门针对 Springboot 与 Hystrix 仪表板的集成。你需要做的就是,

1) 在您的 pom.xml

中添加指标事件流依赖项
<dependency>
    <groupId>com.netflix.hystrix</groupId>
    <artifactId>hystrix-metrics-event-stream</artifactId>
    <version>1.5.5</version>
</dependency>

2) 在您的 SpringApplication 中添加带有 Bean 注释的新 servlet class

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

3) Return 响应 header 的响应具有 text/event-stream MIME 类型。 即使,如果您有另一种内容类型 application/xml,没关系,您也可以使用这种新内容。

HttpHeaders resHeaders = new HttpHeaders();
resHeaders.add("Content-Type", "application/xml; charset=utf-8");
resHeaders.add("Content-Type", "text/event-stream; charset=utf-8");
if(!isError){
return new ResponseEntity<String>(responseXml, resHeaders, HttpStatus.OK);
}
else{
return new ResponseEntity<com.test.pack.fault.Error>(error, resHeaders,HttpStatus.CREATED);
    }

4) 在Tomcat版本7或更高版本的服务器中下载并部署Hystrix仪表板war文件并启动服务器。

5) 使用 url、http://localhost:port/hystrix-dashboard

打开仪表板

6) 在hystrix主页中,添加应用程序url作为http://localhost:port/contextPath(if any)/hystrix.stream。 然后单击添加流按钮并单击监视流按钮。 hystrix.stream 是我们在 servlet 注册中给出的 url 映射。