SpringCloud之HystrixDashBoard豪猪(七)

简介

  除了隔离依赖服务的调用意外,Hystrix还提供了准实时的调用健康(HystrixDashBoard),Hystrix会持续的记录所有通过Hystrix发起的请求的执行信息,并以统计报表和图形的形式展示给用户,包括每秒执行多少请求多少成功,多少失败等;

  Netflix通过hystrix-metrics-event-stream项目实现了对以上指标的监控,springcloud也提供了HystrixDashBoard的整合,对监控内容转化成可视化界面。

环境搭建

新建工程springcloud-consumer-hystrix-dashboard

① 导入pom依赖

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <parent>
    <groupId>com.yt.springcloud</groupId>
    <artifactId>microservicecloud</artifactId>
    <version>0.0.1-SNAPSHOT</version>
  </parent>
  <artifactId>microservicecloud-consumer-hystrix-dashboard</artifactId>

  <dependencies>
        <!-- 自己定义的api -->
        <dependency>
            <groupId>com.yt.springcloud</groupId>
            <artifactId>microservicecloud-api</artifactId>
            <version>${project.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- 修改后立即生效,热部署 -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>springloaded</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
        </dependency>
        <!-- Ribbon相关 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-ribbon</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-config</artifactId>
        </dependency>
        <!-- feign相关 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-feign</artifactId>
        </dependency>
        <!-- hystrix和 hystrix-dashboard相关 -->
        <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>
    </dependencies>
</project>
   

② 编写application.yml配置文件

server:
  port: 9001

③ 添加注解

主启动类添加新注解@EnableHystrixDashboard

 

④ 所有服务提供者的pom配置

所有provider微服务提供类(8001/8002/8003)都需要监控依赖配置

 


测试

  • 启动springcloud-consumer-hystrix-dashboard监控服务
  • 启动3个Eureka集群
  • 启动springcloud-provider-dept-hystrix-8001

地址栏输入:http://localhost:9001/hystrix 测试监控服务好使

测试springcloud-provider-dept-hystrix-8001服务接口是否正常

Hystrix Dashboard的url信息介绍

9001端口在监控8001

启动相关微服务工程

监控测试

 

7 色: 绿 蓝 > 青 > 紫 > 

1 圈: 实心圆 健康度:绿色<黄色<橙色<红色递减;(流量越大实心圆越大,可以在大量的实例中快速的发现(故障实例和高压力测试)

1 线:曲线:用来记录2分钟内流量的相对变化,可以通过它来观察到流量的上升和下降趋势;

 

 

 

posted @ 2019-12-08 22:58  王大军  阅读(419)  评论(0编辑  收藏  举报