热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

详解SpringCloud断路器集群监控(Turbine)

这篇文章主要介绍了详解SpringCloud断路器集群监控(Turbine),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

一. 简介

上一篇文章我们已经实现了对单个服务实例的监控,当然在实际应用中,单个实例的监控数据没有多大的价值,我们更需要的是一个集群系统的监控信息,这时我们就需要引入Turbine。Turbine能够汇集监控信息,并将聚合后的信息提供给Hystrix Dashboard来集中展示和监控。

二. 构建监控局和服务

2.1 整体结构与准备

本文的工程实现是基于上一篇文章的工程,通过引入Turbine来聚合service-ribbon服务的监控信息,并输出给Hystrix Dashboard来进行展示。因为我们需要多个服务的Dashboard,所以我们将构建service-ribbon集群,同时需要新建一个service-turbine工程,用于聚合信息并展示。最终整体架构如下:


2.2 创建service-turbine

新建一个Spring Boot工程,命名为service-turbine,在pom.xml中导入必要的依赖:

<&#63;xml version="1.0" encoding="UTF-8"&#63;> 
 
  4.0.0 
 
  com.dan 
  service-turbine 
  0.0.1-SNAPSHOT 
  jar 
 
  service-turbine 
  Demo project for Spring Boot 
 
   
    org.springframework.boot 
    spring-boot-starter-parent 
    1.5.9.RELEASE 
      
   
 
   
    UTF-8 
    UTF-8 
    1.8 
    Edgware.SR1 
   
 
   
  
 org.springframework.cloud 
 spring-cloud-starter-turbine 
  
  
 org.springframework.cloud 
 spring-cloud-netflix-turbine 
  
  
 org.springframework.boot 
 spring-boot-starter-actuator 
  
 
  
 org.springframework.boot 
 spring-boot-starter-test 
 test 
  
  
 
   
     
       
        org.springframework.cloud 
        spring-cloud-dependencies 
        ${spring-cloud.version} 
        pom 
        import 
       
     
   
 
   
     
       
        org.springframework.boot 
        spring-boot-maven-plugin 
       
     
   
 

在工程启动类上加上@EnableTurbine注解,开启Turbine,该注解已经包含了@EnableDiscoveryClient注解,即已开启了注册服务:

@SpringBootApplication 
@EnableTurbine 
public class ServiceTurbineApplication { 
 
  public static void main(String[] args) { 
    SpringApplication.run(ServiceTurbineApplication.class, args); 
  } 
} 

在application.properties中加入Eureka和Turbine的相关配置,具体如下:

spring.application.name=service-turbine 
server.port=8766 
security.basic.enabled=false 
 
eureka.client.serviceUrl.defaultZOne=http://localhost:8761/eureka 
 
turbine.aggregator.cluster-cOnfig=default 
turbine.app-cOnfig=service-ribbon 
turbine.cluster-name-expression="default" 
turbine.combine-host-port=true 

上面的配置中,turbine.app-config参数配置Eureka中的serviceId列表,表明监控哪些服务;turbine.cluster-name-expression参数指定了集群名称为default,当服务数量非常多的时候,可以启动多个Turbine服务来构建不同的聚合集群,而该参数可以用来区分这些不同的聚合集群,同时该参数值可以再Hystrix仪表盘中用来定位不同的聚合集群,只需在Hystrix Stream的URL中通过cluster参数来指定;turbine.combine-host-port参数设置为true,可以让同一主机上的服务通过主机名与端口号的组合来进行区分,默认情况下会以host来区分不同的服务,这会使得在本机调试的时候,本机上的不同服务聚合成一个服务来统计。

三. 集群监控

启动eureka-server工程,端口号为8761;

启动eureka-client工程,端口号为8762和8763;

启动service-ribbon工程,端口号为8764和8765;

启动service-turbine工程,端口号为8766。

访问http://localhost:8766/turbine.stream看到:


     

访问http://localhost:8765/hystrix,输入监控流http://localhost:8766/turbine.stream看到:


在图中可以看到,虽然我们启动了两个service-ribbon,但是监控页面中依然只是展示了一个监控图。不过我们可以发现,图中集群报告区域中的Hosts属性与之前尝试单机监控时已有不同,只是因为这两个实例是同一个服务,而对于集群来说我们关注的是服务集群的高可用性,所以Turbine会将相同服务作为整体来看待,并汇总成一个监控图。

当然啦,如果你真想看到两个监控图,可以把service-ribbon其中的一个实例的spring.application.name设置成别的名称,这样运行起来后就会出现两个不同的监控图。

四. 与消息代理结合

Spring Cloud在封装Turbine的时候,还封装了基于消息代理的收集实现。所以,我们可以将所有需要收集的监控信息都输出到消息代理中,然后Turbine服务再从消息代理中异步获取这些监控信息,最后将这些监控信息聚合并输出到Hystrix Dashboard中。通过引入消息代理,我们的Turbine和Hystrix Dashboard实现的监控架构可以改成如下图所示的结构:


首先新建一个Spring Boot工程,命名为service-turbine-amqp,引入spring-cloud-starter-turbine-amqp和spring-boot-starter-actuator依赖。看到这里只是引入这两个依赖,因为spring-cloud-starter-turbine-amqp实际上包装了spring-cloud-starter-turbine-stream和spring-cloud-starter-stream-rabbit。

<&#63;xml version="1.0" encoding="UTF-8"&#63;> 
 
  4.0.0 
 
  com.dan 
  service-turbine-amqp 
  0.0.1-SNAPSHOT 
  jar 
 
  service-turbine-amqp 
  Demo project for Spring Boot 
 
   
    org.springframework.boot 
    spring-boot-starter-parent 
    1.5.9.RELEASE 
      
   
 
   
    UTF-8 
    UTF-8 
    1.8 
    Edgware.SR1 
   
 
   
     
      org.springframework.cloud 
      spring-cloud-starter-turbine-amqp 
     
 
           org.springframework.boot 
      spring-boot-starter-actuator 
      test 
     
   
 
   
     
       
        org.springframework.cloud 
        spring-cloud-dependencies 
        ${spring-cloud.version} 
        pom 
        import 
       
     
   
 
   
     
       
        org.springframework.boot 
        spring-boot-maven-plugin 
       
     
   
 

在主类中使用@EnableTurbineStream注解来启用Turbine Stream的配置:

@SpringBootApplication 
@EnableTurbineStream 
@EnableDiscoveryClient 
public class ServiceTurbineAmqpApplication { 
 
  public static void main(String[] args) { 
    SpringApplication.run(ServiceTurbineAmqpApplication.class, args); 
  } 
} 

接着配置application.properties文件:

spring.application.name=service-turbine-amqp 
server.port=8766 
eureka.client.serviceUrl.defaultZOne=http://localhost:8761/eureka 

对于Turbine的配置已经完成了,下面需要对service-ribbon做一些修改,使其监控信息能够输出到RabbitMQ上。这个修改也非常简单,只需在pom.xml中增加对spring-cloud-netflix-hystrix-amqp的依赖,具体如下:

 
  org.springframework.cloud 
  spring-cloud-netflix-hystrix-amqp 
 

完成上面的配置后,同样启动所有需要的工程,同样访问http://localhost:8765/hystrix,输入监控流http://localhost:8766/turbine.stream,我们可以看到跟之前同样的结果,只是这里的监控信息收集是通过消息代理异步实现的。

源码下载:https://github.com/lingd3/SpringCloudLearning/tree/master/chapter8

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • Java如何导入和导出Excel文件的方法和步骤详解
    本文详细介绍了在SpringBoot中使用Java导入和导出Excel文件的方法和步骤,包括添加操作Excel的依赖、自定义注解等。文章还提供了示例代码,并将代码上传至GitHub供访问。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • 本文介绍了一些Java开发项目管理工具及其配置教程,包括团队协同工具worktil,版本管理工具GitLab,自动化构建工具Jenkins,项目管理工具Maven和Maven私服Nexus,以及Mybatis的安装和代码自动生成工具。提供了相关链接供读者参考。 ... [详细]
  • Android日历提醒软件开源项目分享及使用教程
    本文介绍了一款名为Android日历提醒软件的开源项目,作者分享了该项目的代码和使用教程,并提供了GitHub项目地址。文章详细介绍了该软件的主界面风格、日程信息的分类查看功能,以及添加日程提醒和查看详情的界面。同时,作者还提醒了读者在使用过程中可能遇到的Android6.0权限问题,并提供了解决方法。 ... [详细]
  • Skywalking系列博客1安装单机版 Skywalking的快速安装方法
    本文介绍了如何快速安装单机版的Skywalking,包括下载、环境需求和端口检查等步骤。同时提供了百度盘下载地址和查询端口是否被占用的命令。 ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • 学习笔记(34):第三阶段4.2.6:SpringCloud Config配置中心的应用与原理第三阶段4.2.6SpringCloud Config配置中心的应用与原理
    立即学习:https:edu.csdn.netcourseplay29983432482?utm_sourceblogtoedu配置中心得核心逻辑springcloudconfi ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • Activiti7流程定义开发笔记
    本文介绍了Activiti7流程定义的开发笔记,包括流程定义的概念、使用activiti-explorer和activiti-eclipse-designer进行建模的方式,以及生成流程图的方法。还介绍了流程定义部署的概念和步骤,包括将bpmn和png文件添加部署到activiti数据库中的方法,以及使用ZIP包进行部署的方式。同时还提到了activiti.cfg.xml文件的作用。 ... [详细]
  • 本文讨论了在shiro java配置中加入Shiro listener后启动失败的问题。作者引入了一系列jar包,并在web.xml中配置了相关内容,但启动后却无法正常运行。文章提供了具体引入的jar包和web.xml的配置内容,并指出可能的错误原因。该问题可能与jar包版本不兼容、web.xml配置错误等有关。 ... [详细]
author-avatar
昙檀禅潺_162
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有