Hystrix-dashboard 是一款针对 Hystrix 进行实时监控的工具,通过 Hystrix Dashboard 我们可以在直观地看到各 Hystrix Command 的请求响应时间, 请求成功率等数据。但是只使用 Hystrix Dashboard 的话, 你只能看到单个应用内的服务信息, 这明显不够. 我们需要一个工具能让我们汇总系统内多个服务的数据并显示到 Hystrix Dashboard 上, 这个工具就是 Turbine.
Hystrix Dashboard
我们在熔断示例项目 spring-cloud-consumer-hystrix 的基础上更改,重新命名为:spring-cloud-consumer-hystrix-dashboard。
1、添加依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix-dashboard</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
这三个包必须添加
2、启动类
启动类添加启用 Hystrix Dashboard 和熔断器
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
@EnableHystrixDashboard
@EnableCircuitBreaker
public class ConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(ConsumerApplication.class, args);
}
}
3、测试
启动工程后访问 http ://localhost:9001/hystrix,将会看到如下界面:
图中会有一些提示:
Cluster via Turbine (default cluster): http://turbine-hostname:port/turbine.stream
Cluster via Turbine (custom cluster): http://turbine-hostname:port/turbine.stream?cluster=[clusterName]
Single Hystrix App: http://hystrix-app:port/hystrix.stream
大概意思就是如果查看默认集群使用第一个 url,查看指定集群使用第二个 url,单个应用的监控使用最后一个,我们暂时只演示单个应用的所以在输入框中输入: localhost:9001/hystrix.stream ,输入之后点击 monitor,进入页面。
如果没有请求会先显示 Loading ...,访问 http://localhost:9001/hystrix.stream 也会不断的显示 ping。
请求服务 http://localhost:9001/hello/neo,就可以看到监控的效果了,首先访问 http://localhost:9001/hystrix.stream,显示如下:
ping:
data: {"type":...}
data: {"type":...}
说明已经返回了监控的各项结果
到监控页面就会显示如下图:
其实就是 http ://localhost:9001/hystrix.stream 返回结果的图形化显示,Hystrix Dashboard Wiki 上详细说明了图上每个指标的含义,如下图:
到此单个应用的熔断监控已经完成。
技术架构图如下:
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于