zoukankan      html  css  js  c++  java
  • SpringCloud教程 | 第十三篇: 断路器聚合监控(Hystrix Turbine)

    分类专栏: springcloud 史上最简单的 Spring Cloud 教程

    转载请标明出处:
    原文首发于:https://www.fangzhipeng.com/springcloud/2018/08/30/sc-f13-turbine/
    本文出自方志朋的博客

    个人博客纯净版:https://www.fangzhipeng.com/springcloud/2018/08/13/sc-f13-turbine.html

    上一篇文章讲述了如何利用Hystrix Dashboard去监控断路器的Hystrix command。当我们有很多个服务的时候,这就需要聚合所以服务的Hystrix Dashboard的数据了。这就需要用到Spring Cloud的另一个组件了,即Hystrix Turbine。

    一、Hystrix Turbine简介

    看单个的Hystrix Dashboard的数据并没有什么多大的价值,要想看这个系统的Hystrix Dashboard数据就需要用到Hystrix Turbine。Hystrix Turbine将每个服务Hystrix Dashboard数据进行了整合。Hystrix Turbine的使用非常简单,只需要引入相应的依赖和加上注解和配置就可以了。

    二、准备工作

    本文使用的工程为上一篇文章的工程,在此基础上进行改造。因为我们需要多个服务的Dashboard,所以需要再建一个服务,取名为service-lucy,它的基本配置同service-hi,具体见源码,在这里就不详细说明。

    三、创建service-turbine

    引入相应的依赖:

     <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-actuator</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-turbine</artifactId>
            </dependency>
    
        </dependencies>

    在其入口类ServiceTurbineApplication加上注解@EnableTurbine,开启turbine,@EnableTurbine注解包含了@EnableDiscoveryClient注解,即开启了注册服务。

    
    @SpringBootApplication
    @EnableEurekaClient
    @EnableDiscoveryClient
    @RestController
    @EnableHystrix
    @EnableHystrixDashboard
    @EnableCircuitBreaker
    @EnableTurbine
    public class ServiceTurbineApplication {
    
        /**
         * http://localhost:8764/turbine.stream
         */
    
        public static void main(String[] args) {
            SpringApplication.run( ServiceTurbineApplication.class, args );
        }
    }

    配置文件application.yml:

    server:
      port: 8764
    
    spring:
      application:
        name: service-turbine
    
    eureka:
      client:
        serviceUrl:
          defaultZone: http://localhost:8761/eureka/
    management:
      endpoints:
        web:
          exposure:
            include: "*"
          cors:
            allowed-origins: "*"
            allowed-methods: "*"
    
    turbine:
      app-config: service-hi,service-lucy
      aggregator:
        clusterConfig: default
      clusterNameExpression: new String("default")
      combine-host: true
      instanceUrlSuffix:
        default: actuator/hystrix.stream     
    

    配置文件注解写的很清楚。

    四、Turbine演示

    依次开启eureka-server、service-hi、service-lucy、service-turbine工程。

    打开浏览器输入:http://localhost:8764/turbine.stream,界面如下:

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Mprwy3z2-1569837780939)(https://img-blog.csdn.net/20170416135735474?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZm9yZXpw/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)]

    依次请求:

    http://localhost:8762/hi?name=forezp

    http://localhost:8763/hi?name=forezp

    打开:http://localhost:8763/hystrix,输入监控流http://localhost:8764/turbine.stream

    这里写图片描述

    点击monitor stream 进入页面:

    这里写图片描述

    可以看到这个页面聚合了2个service的hystrix dashbord数据。

    源码下载:
    https://github.com/forezp/SpringCloudLearning/tree/master/sc-f-chapter13

    五、参考文献

    hystrix_dashboard

    turbine

    更多阅读

    史上最简单的 SpringCloud 教程汇总

    SpringBoot教程汇总

    Java面试题系列汇总

  • 相关阅读:
    【Swift】WKWebView与JS的交互使用
    【React Native】进阶指南之二(手势响应系统)
    【React Native】进阶指南之一(特定平台、图片加载、动画使用)
    React Native适配IPhoneX系列设备之<SafeAreaView />
    【React Native】react-native之集成支付宝支付、微信支付
    【React Natvie】React-native-swiper的安装和配置【ES6】
    React Native之React Navigation踩坑
    遭遇裁员,如何渡过心理危机?
    Spring 核心技术与产品理念剖析【下】
    Spring 核心技术与产品理念剖析【上】
  • 原文地址:https://www.cnblogs.com/lixiaochong/p/13610386.html
Copyright © 2011-2022 走看看