1.Hystrix服务监控Dashboard 介绍

Hystrix服务监控Dashboard仪表盘

在实际生产中,成千上万的服务,我们怎么知道提供服务的高可用情况,即服务的成功失败超时等相关情况;

Hystrix提供了,实时的服务调用监控项目Dashboard,能够实时记录通过Hystrix发起的请求执行情况,并可以通过图表的形式展现给用户看,非常的直观

 2.具体实现

 第一步:构建Dashboard监控模块,模块名称为:hystrix-dashboard-8080,端口号为:8080

 

接口监控 接口监控dashboard_接口监控

pom.xml文件导入jar包如下:

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

application.yml文件

server:
  port: 8080
  context-path: /

启动类:DashboardApplication_8080,

注意添加注解:@EnableHystrixDashboard

接口监控 接口监控dashboard_接口监控_02

接口监控 接口监控dashboard_spring_03

package com.wfd360;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration;
import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard;

/**
 * @author 姿势帝-博客园
 * @address 
 * @WeChat 851298348
 * @create 07/19 5:12
 * @description
 */
@SpringBootApplication(exclude={DataSourceAutoConfiguration.class, HibernateJpaAutoConfiguration.class})
@EnableHystrixDashboard
public class DashboardApplication_8080 {
    public static void main(String[] args) {
        SpringApplication.run(DashboardApplication_8080.class, args);
    }
}

View Code

启动项目: hystrix-dashboard-8080

访问:http://localhost:8080/hystrix.stream

界面如下:

接口监控 接口监控dashboard_ci_04

 部署成功!

第二步:启动项目 ticket-lock-provider-6004

这里注意,需要保证 ticket-lock-provider-6004 为 hystrix项目

即:

1.application.yml上配置超时时间

2.启动类上添加注解  @EnableCircuitBreaker

3.控制层方法上有服务熔断降级处理

接口监控 接口监控dashboard_接口监控_05

其实就是上一节中注释的代码全部打开

验证服务提供者配置是否成功

访问:http://localhost:6004/lock/ticket/10 ,看能否正常获取数据或服务熔断

访问:http://localhost:6004/hystrix.stream ,看能否不断ping 出如下数据

接口监控 接口监控dashboard_ide_06

 这些数据我们看起来很困难,但是只要借助Dashboard项目,看起来就是仪表盘了

第三步:将连接 http://localhost:6004/hystrix.stream 放入dashboard的中进行检测 http://localhost:8080/hystrix.stream

接口监控 接口监控dashboard_ide_07

 生产监测报表如下:

接口监控 接口监控dashboard_ci_08

 测试时,你可以不断的访问6004服务,观察报表的变化情况!

简要说一下图的含义
下面灰色的圆圈代表是健康情况,如果红色代表不健康,形状越大流量越大
凸起来的灰色线,代表的是访问的流量的变化情况
第一列 针对的是request
第一个绿色的数字,代表成功访问请求的数量,对应横向的绿色Success。
第二个蓝色的数字,代表Short-Circuited
第三个青色的数字,代表错误请求的数量
第二列 针对的是response
第一个橙色的数字,代表超时访问的数量
第二个紫色的数字,代表拒绝访问的数量
第三个红色的数字,代表失败的服务数量
第三列 针对的是request/response 错误比例 或者成功比例
最重要的一个指标是参考 Circuit 代表熔断器的状态 close的关闭,open是打开

图标中个数据的含义:

接口监控 接口监控dashboard_ci_09