欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Spring Cloud第六篇 | Hystrix仪表盘监控Hystrix Dashboard

程序员文章站 2022-05-18 19:31:04
世界原本就不是属于你,因此你用不着抛弃,要抛弃的是一切的执着。万物皆为我所用,但非我所属。 ......

Spring Cloud第六篇 | Hystrix仪表盘监控Hystrix Dashboard

本文是spring cloud专栏的第六篇文章,了解前五篇文章内容有助于更好的理解本文:

  1. spring cloud第一篇 | spring cloud前言及其常用组件介绍概览

  2. spring cloud第二篇 | 使用并认识eureka注册中心

  3. spring cloud第三篇 | 搭建高可用eureka注册中心

  4. spring cloud第四篇 | 客户端负载均衡ribbon

  5. spring cloud第五篇 | 服务熔断hystrix

Spring Cloud第六篇 | Hystrix仪表盘监控Hystrix Dashboard

一、hystrix仪表盘监控

    hystrix仪表盘( hystrix dashboard),就像汽车的仪表盘实时显示汽车的各 项数据一样, hystrix仪表盘主要用来监控 hystrix的实时运行状态,通过它我们可以看到 hystrix的各项指标信息,从而快速发现系统中存在的问题进而解决 要使用 hystriⅸ仪表盘功能,我们首先需要有一个 hystrix dashboard,这个功能我们可以在原来的消费者应用上添加,让原来的消费者应用具备hysr仪表 盘功能,但一般地微服务架构思想是推崇服务的拆分, hystrix dashboard也是一个服务,所以通常会单独创建一个新的工程专门用做 hystrix dashboard 服务,hystrix dashboard所处的作用如图

Spring Cloud第六篇 | Hystrix仪表盘监控Hystrix Dashboard

1、新建一个模块命名为(springcloud-hystrix-dashboard)

2、添加依赖hystrix的dashboard依赖

<!--hystrix-dashboard功能的起步依赖,仪表盘功能-->
<dependency>
  <groupid>org.springframework.cloud</groupid>
  <artifactid>spring-cloud-starter-netflix-hystrix-dashboard</artifactid>
</dependency>

此时依赖可能下载不下来,可以添加阿里云仓库

<repositories>
    <repository>
        <id>alimaven</id>
        <name>aliyun maven</name>
        <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
        <releases>
            <enabled>true</enabled>
        </releases>
        <snapshots>
            <enabled>false</enabled>
        </snapshots>
    </repository>
</repositories>

3、在启动类上添加注解@enablehystrixdashboard

4、端口配置为3721,到此我们的hystrix监控服务就搭建完毕了,启动访问http://localhost:3721/hystrix

Spring Cloud第六篇 | Hystrix仪表盘监控Hystrix Dashboard

    hystrix仪表盘工程已经创建好了,我们需要有一个服务,让这个服务提供一个路径为/actuator/hystrix.stream接口,然后就可以使用hystrix仪表盘来对该服务进行监控了

5、改造消费者(springcloud-service-consumer)

我们改造消费者服务,让其能提供/actuator/hystrix.stream接口,步骤如下:

    5-1、消费者项目需要有hystrix的依赖,在之前案例中使用服务熔断的时候已经加过了

    5-2、需要有一个springboot的服务监控依赖,可以直接添加到父模块依赖中

<!--springboot提供的服务健康检查监控的依赖-->
<dependency>
  <groupid>org.springframework.boot</groupid>
  <artifactid>spring-boot-starter-actuator</artifactid>
</dependency>

    5-3、配置文件需要配置springboot监控的端点访问权限

#用来暴露endpoints的,由于endpoints中会包含很多敏感信息,
#除了health和info两个支持直接访问外,其他的默认不能直接访问,
#所以我们让他们都能访问(*),或者指定springboot的监控端点访问权限,
#*表示所有的端点都允许访问,如果只写hystrix.stream,他会把默认的info,health端点关闭
management:
  endpoints:
    web:
      exposure:
        include: ["info","health","hystrix.stream"]

从控制台日志上可以看到

2019-08-07 15:58:31.187  info 7396 --- [ost-startstop-1] o.s.b.a.e.web.servletendpointregistrar   : registered '/actuator/hystrix.stream' to hystrix.stream-actuator-endpoint

6、第一次访问,要先访问其他带用熔断器的接口,访问入口:http://localhost:9090/actuator/hystrix.stream

    注意:这里有一个细节需要注意,要访问/hystrix.stream接口,首先访问消费者(springcloud-service-consumer)工程中任意的一个带有熔断器的接口,否则直接访问/hystrix.stream接口时,会输出一连串ping:    ping: ....

7、把http://localhost:9090/actuator/hystrix.stream填写到hystrix dashboard仪表盘上,直接在网上找了一个详细描述图,如下图

Spring Cloud第六篇 | Hystrix仪表盘监控Hystrix Dashboard

 

详细参考案例源码:

 

 Spring Cloud第六篇 | Hystrix仪表盘监控Hystrix Dashboard

Spring Cloud第六篇 | Hystrix仪表盘监控Hystrix Dashboard