springcloud(五):熔断监控Hystrix Dashboard

Hystrix-dashboard是一款针对Hystrix进行实时监控的工具,经过Hystrix Dashboard咱们能够在直观地看到各Hystrix Command的请求响应时间, 请求成功率等数据。可是只使用Hystrix Dashboard的话, 你只能看到单个应用内的服务信息, 这明显不够. 咱们须要一个工具能让咱们汇总系统内多个服务的数据并显示到Hystrix Dashboard上, 这个工具就是Turbine.愿意了解源码的朋友直接求求交流分享技术:二一四七七七五六三三spring

Hystrix Dashboard
咱们在熔断示例项目spring-cloud-consumer-hystrix的基础上更改,从新命名为:spring-cloud-consumer-hystrix-dashboard。架构

一、添加依赖app

<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>

这三个包必须添加spring-boot

二、启动类
启动类添加启用Hystrix Dashboard和熔断器工具

@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
@EnableHystrixDashboard
@EnableCircuitBreaker
public class ConsumerApplication {
 
    public static void main(String[] args) {
        SpringApplication.run(ConsumerApplication.class, args);
    }
}

三、测试
启动工程后访问 http://localhost:9001/hystrix,将会看到以下界面:测试

图中会有一些提示:ui

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,单个应用的监控使用最后一个,咱们暂时只演示单个应用的因此在输入框中输入: http://localhost:9001/hystrix.stream ,输入以后点击 monitor,进入页面。url

若是没有请求会先显示Loading ...,访问http://localhost:9001/hystrix.stream 也会不断的显示ping。3d

请求服务http://localhost:9001/hello/neo,就能够看到监控的效果了,首先访问http://localhost:9001/hystrix.stream,显示以下:code

ping: 
 
data: {"type":...}
 
data: {"type":...}

说明已经返回了监控的各项结果

到监控页面就会显示以下图:

其实就是http://localhost:9001/hystrix.stream返回结果的图形化显示,Hystrix Dashboard Wiki上详细说明了图上每一个指标的含义,以下图:

到此单个应用的熔断监控已经完成。

技术架构图以下:

 

相关文章
相关标签/搜索