Hystrix 仪表板不工作

Kal*_*pan 5 java spring-boot hystrix

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

2016-10-04 07:23:28 INFO  com.netflix.turbine.discovery.InstanceObservable$1:289 [InstanceObservable$1] [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 
Run Code Online (Sandbox Code Playgroud)

Kal*_*pan 4

找到答案了。我们需要在响应头中添加 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>
Run Code Online (Sandbox Code Playgroud)

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

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

3) 返回具有文本/事件流 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);
    }
Run Code Online (Sandbox Code Playgroud)

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

5) 使用 url 打开仪表板,http://localhost:port/hystrix-dashboard

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

  • 你好,谢谢,它对我有用。第3部分不清楚,但没有必要使用它。 (2认同)