Turbine使用
一、简介
Turbine是聚合服务器发送事件流数据的一个工具,Hystrix的监控中,只能监控单个节点,实际生产中都为集群,因此可以通过Turbine来监控集群下Hystrix的metrics情况
Turbine的github地址:https://github.com/Netflix/Turbine
二、基本环境
- 一个eureka模块
- 两个消费者模块
- 一个turbine监控模块
三、创建eureka模块
(1)创建项目
创建一个spring boot项目

(2)依赖
-
<?xml version="1.0" encoding="UTF-8"?>
-
<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>
-
-
<groupId>com.abc</groupId>
-
<artifactId>00-eurekaserver-8000</artifactId>
-
<version>0.0.1-SNAPSHOT</version>
-
<packaging>jar</packaging>
-
-
<parent>
-
<groupId>org.springframework.boot</groupId>
-
<artifactId>spring-boot-starter-parent</artifactId>
-
<version>2.1.7.RELEASE</version>
-
<relativePath/> <!-- lookup parent from repository -->
-
</parent>
-
-
<properties>
-
<java.version>1.8</java.version>
-
<spring-cloud.version>Greenwich.SR2</spring-cloud.version>
-
</properties>
-
-
<dependencies>
-
<dependency>
-
<groupId>org.springframework.cloud</groupId>
-
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
-
</dependency>
-
-
<dependency>
-
<groupId>org.springframework.boot</groupId>
-
<artifactId>spring-boot-starter-test</artifactId>
-
<scope>test</scope>
-
</dependency>
-
-
<!--热部署依赖-->
-
<dependency>
-
<groupId>org.springframework.boot</groupId>
-
<artifactId>spring-boot-devtools</artifactId>
-
<optional>true</optional>
-
</dependency>
-
</dependencies>
-
-
<dependencyManagement>
-
<dependencies>
-
<dependency>
-
<groupId>org.springframework.cloud</groupId>
-
<artifactId>spring-cloud-dependencies</artifactId>
-
<version>${spring-cloud.version}</version>
-
<type>pom</type>
-
<scope>import</scope>
-
</dependency>
-
</dependencies>
-
</dependencyManagement>
-
-
<build>
-
<plugins>
-
<plugin>
-
<groupId>org.springframework.boot</groupId>
-
<artifactId>spring-boot-maven-plugin</artifactId>
-
</plugin>
-
</plugins>
-
</build>
-
-
</project>
(3)application.yml配置
-
server:
-
port: 8000
-
-
eureka:
-
instance:
-
hostname: localhost # 指定Eureka主机
-
client:
-
register-with-eureka: false # 指定当前主机是否向Eureka服务器进行注册
-
fetch-registry: false # 指定当前主机是否要从Eurka服务器下载服务注册列表
-
service-url: # 服务暴露地址
-
defaultZone: http://localhost:8000/eureka
-
# defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka
-
-
# server:
-
# enable-self-preservation: false # 关闭自我保护
(4)启动类
-
package com.abc.eureka;
-
-
import org.springframework.boot.SpringApplication;
-
import org.springframework.boot.autoconfigure.SpringBootApplication;
-
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
-
-
@SpringBootApplication
-
@EnableEurekaServer // 开启Eureka服务
-
public class EurekaServerApplication {
-
-
public static void main(String[] args) {
-
SpringApplication.run(EurekaServerApplication.class, args);
-
}
-
}
四、创建消费者09-consumer-turbine-8080
(1)创建项目
创建一个spring boot项目

(2)依赖
-
<?xml version="1.0" encoding="UTF-8"?>
-
<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>org.springframework.boot</groupId>
-
<artifactId>spring-boot-starter-parent</artifactId>
-
<version>2.1.7.RELEASE</version>
-
<relativePath/> <!-- lookup parent from repository -->
-
</parent>
-
<groupId>com.abc</groupId>
-
<artifactId>09-consumer-turbine-8080</artifactId>
-
<version>0.0.1-SNAPSHOT</version>
-
<name>09-consumer-turbine-8080</name>
-
<description>Demo project for Spring Boot</description>
-
-
<properties>
-
<java.version>1.8</java.version>
-
<spring-cloud.version>Greenwich.SR2</spring-cloud.version>
-
</properties>
-
-
<dependencies>
-
-
<!--hystrix依赖-->
-
<dependency>
-
<groupId>org.springframework.cloud</groupId>
-
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
-
</dependency>
-
-
<!--feign依赖-->
-
<dependency>
-
<groupId>org.springframework.cloud</groupId>
-
<artifactId>spring-cloud-starter-openfeign</artifactId>
-
</dependency>
-
-
<!-- hystrix-dashboard依赖 -->
-
<dependency>
-
<groupId>org.springframework.cloud</groupId>
-
<artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
-
</dependency>
-
-
<!--actuator依赖-->
-
<dependency>
-
<groupId>org.springframework.boot</groupId>
-
<artifactId>spring-boot-starter-actuator</artifactId>
-
</dependency>
-
-
<!--eureka客户端依赖-->
-
<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>
-
-
<!-- https://mvnrepository.com/artifact/org.webjars.bower/jquery -->
-
<dependency>
-
<groupId>org.webjars.bower</groupId>
-
<artifactId>jquery</artifactId>
-
<version>2.1.1</version>
-
</dependency>
-
-
<dependency>
-
<groupId>org.projectlombok</groupId>
-
<artifactId>lombok</artifactId>
-
<optional>true</optional>
-
</dependency>
-
-
<dependency>
-
<groupId>org.springframework.cloud</groupId>
-
<artifactId>spring-cloud-starter-netflix-turbine</artifactId>
-
</dependency>
-
<!--热部署依赖-->
-
<dependency>
-
<groupId>org.springframework.boot</groupId>
-
<artifactId>spring-boot-devtools</artifactId>
-
<optional>true</optional>
-
</dependency>
-
-
</dependencies>
-
-
<dependencyManagement>
-
<dependencies>
-
<dependency>
-
<groupId>org.springframework.cloud</groupId>
-
<artifactId>spring-cloud-dependencies</artifactId>
-
<version>${spring-cloud.version}</version>
-
<type>pom</type>
-
<scope>import</scope>
-
</dependency>
-
</dependencies>
-
</dependencyManagement>
-
-
<build>
-
<plugins>
-
<plugin>
-
<groupId>org.springframework.boot</groupId>
-
<artifactId>spring-boot-maven-plugin</artifactId>
-
</plugin>
-
</plugins>
-
</build>
-
-
</project>
(3)application.yml配置
-
# 在微服务网关zuul中演示时需要该工程的端口号为8090
-
server:
-
port: 8080
-
-
spring:
-
application: # 指定微服务对外暴露的名称
-
name: abcmsc-consumer-depart01
-
-
eureka:
-
client:
-
service-url:
-
defaultZone: http://localhost:8000/eureka
-
# instance:
-
# metadata-map:
-
# cluster: ribbon
-
# 开启Feign对Hystrix的支持
-
feign:
-
hystrix:
-
enabled: true
-
-
client:
-
config:
-
default:
-
connectTimeout: 5000 # 指定Feign连接提供者的超时时限
-
readTimeout: 5000 # 指定Feign从请求到获取提供者响应的超时时限
-
-
# 开启actuator的所有web终端
-
management:
-
endpoints:
-
web:
-
exposure:
-
include: "*"
-
-
# 设置服务熔断时限
-
hystrix:
-
command:
-
default:
-
execution:
-
isolation:
-
thread:
-
timeoutInMilliseconds: 3000
(4)实体类Depart
-
package com.abc.consumer.bean;
-
-
import lombok.Data;
-
-
@Data
-
public class Depart {
-
private Integer id;
-
private String name;
-
}
(5)DepartCodeConfig类
-
package com.abc.consumer.codeconfig;
-
-
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
-
import org.springframework.context.annotation.Bean;
-
import org.springframework.context.annotation.Configuration;
-
import org.springframework.web.client.RestTemplate;
-
-
@Configuration
-
public class DepartCodeConfig {
-
-
@LoadBalanced // 开启消息者端的负载均衡功能,默认是轮询策略
-
@Bean
-
public RestTemplate restTemplate() {
-
return new RestTemplate();
-
}
-
-
}
(6)DepartController类
-
package com.abc.consumer.controller;
-
-
import com.abc.consumer.bean.Depart;
-
import com.abc.consumer.service.DepartService;
-
import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
-
import org.springframework.beans.factory.annotation.Autowired;
-
import org.springframework.web.bind.annotation.*;
-
-
import java.util.List;
-
-
@RestController
-
@RequestMapping("/consumer/depart")
-
public class DepartController {
-
-
@Autowired
-
DepartService service;
-
-
// 服务降级:若当前处理器方法发生异常,则执行fallbackMethod属性指定的方法
-
@HystrixCommand(fallbackMethod = "getHystrixHandle")
-
@GetMapping("/get/{id}")
-
public Depart getHandle(@PathVariable("id") int id) {
-
return service.getDepartById(id);
-
}
-
-
public Depart getHystrixHandle(@PathVariable("id") int id) {
-
Depart depart = new Depart();
-
depart.setId(id);
-
depart.setName("no this depart -- 方法级别");
-
return depart;
-
}
-
-
-
}
(7)DepartService类
-
package com.abc.consumer.service;
-
-
-
import com.abc.consumer.bean.Depart;
-
import org.springframework.cloud.openfeign.FeignClient;
-
import org.springframework.stereotype.Service;
-
import org.springframework.web.bind.annotation.*;
-
-
import java.util.List;
-
-
@Service
-
// 指定当前Service所绑定的提供者微服务名称
-
// fallback指定该接口所绑定的服务降级类
-
@FeignClient(value = "abcmsc-provider-depart")
-
@RequestMapping("/provider/depart")
-
public interface DepartService {
-
@GetMapping("/get/{id}")
-
Depart getDepartById(@PathVariable("id") int id);
-
-
}
(8)启动类
-
package com.abc.consumer;
-
-
import org.springframework.boot.SpringApplication;
-
import org.springframework.cloud.client.SpringCloudApplication;
-
import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard;
-
import org.springframework.cloud.openfeign.EnableFeignClients;
-
-
// 指定Service接口所在的包,开启OpenFeign客户端
-
@EnableFeignClients(basePackages = "com.abc.consumer.service")
-
@SpringCloudApplication
-
@EnableHystrixDashboard // 开启Hystrix仪表盘功能
-
public class Consumer01Application {
-
-
public static void main(String[] args) {
-
SpringApplication.run(Consumer01Application.class, args);
-
}
-
-
}
五、创建消费者09-consumer-turbine-8081
(1)复制项目09-consumer-turbine-8080

(2)修改依赖

(3)修改application.yml配置

(4)修改09-consumer-turbine-8081.iml

六、创建消费者turbine监控
(1)创建项目
创建一个spring boot项目

(2)依赖
-
<?xml version="1.0" encoding="UTF-8"?>
-
<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>org.springframework.boot</groupId>
-
<artifactId>spring-boot-starter-parent</artifactId>
-
<version>2.1.7.RELEASE</version>
-
<relativePath/> <!-- lookup parent from repository -->
-
</parent>
-
<groupId>com.abc</groupId>
-
<artifactId>09-consumer-turbine-monitor-9000</artifactId>
-
<version>0.0.1-SNAPSHOT</version>
-
<name>09-consumer-turbine-monitor-9000</name>
-
<description>Demo project for Spring Boot</description>
-
-
<properties>
-
<java.version>1.8</java.version>
-
<spring-cloud.version>Greenwich.SR2</spring-cloud.version>
-
</properties>
-
-
<dependencies>
-
-
<dependency>
-
<groupId>org.springframework.cloud</groupId>
-
<artifactId>spring-cloud-starter-netflix-turbine</artifactId>
-
</dependency>
-
-
<!--hystrix依赖-->
-
<dependency>
-
<groupId>org.springframework.cloud</groupId>
-
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
-
</dependency>
-
-
<!--feign依赖-->
-
<dependency>
-
<groupId>org.springframework.cloud</groupId>
-
<artifactId>spring-cloud-starter-openfeign</artifactId>
-
</dependency>
-
-
<!-- hystrix-dashboard依赖 -->
-
<dependency>
-
<groupId>org.springframework.cloud</groupId>
-
<artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
-
</dependency>
-
-
<!--actuator依赖-->
-
<dependency>
-
<groupId>org.springframework.boot</groupId>
-
<artifactId>spring-boot-starter-actuator</artifactId>
-
</dependency>
-
-
<!--eureka客户端依赖-->
-
<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>
-
-
<!-- https://mvnrepository.com/artifact/org.webjars.bower/jquery -->
-
<dependency>
-
<groupId>org.webjars.bower</groupId>
-
<artifactId>jquery</artifactId>
-
<version>2.1.1</version>
-
</dependency>
-
-
<dependency>
-
<groupId>org.projectlombok</groupId>
-
<artifactId>lombok</artifactId>
-
<optional>true</optional>
-
</dependency>
-
<!--热部署依赖-->
-
<dependency>
-
<groupId>org.springframework.boot</groupId>
-
<artifactId>spring-boot-devtools</artifactId>
-
<optional>true</optional>
-
</dependency>
-
-
</dependencies>
-
<dependencyManagement>
-
<dependencies>
-
<dependency>
-
<groupId>org.springframework.cloud</groupId>
-
<artifactId>spring-cloud-dependencies</artifactId>
-
<version>${spring-cloud.version}</version>
-
<type>pom</type>
-
<scope>import</scope>
-
</dependency>
-
</dependencies>
-
</dependencyManagement>
-
-
<build>
-
<plugins>
-
<plugin>
-
<groupId>org.springframework.boot</groupId>
-
<artifactId>spring-boot-maven-plugin</artifactId>
-
</plugin>
-
</plugins>
-
</build>
-
-
</project>
(3)application.yml配置
-
-
server:
-
port: 9000
-
-
spring:
-
application: # 指定微服务对外暴露的名称
-
name: 09-consumer-turbine-monitor-9000
-
-
eureka:
-
client:
-
service-url: # 指定Eureka服务注册中心
-
defaultZone: http://localhost:8000/eureka
-
-
# 开启Feign对Hystrix的支持
-
feign:
-
hystrix:
-
enabled: true
-
-
client:
-
config:
-
default:
-
connectTimeout: 5000 # 指定Feign连接提供者的超时时限
-
readTimeout: 5000 # 指定Feign从请求到获取提供者响应的超时时限
-
-
# 开启actuator的所有web终端
-
management:
-
endpoints:
-
web:
-
exposure:
-
include: "*"
-
-
# 设置服务熔断时限
-
hystrix:
-
command:
-
default:
-
execution:
-
isolation:
-
thread:
-
timeoutInMilliseconds: 3000
-
turbine:
-
app-config: abcmsc-consumer-depart01,abcmsc-consumer-depart02
-
cluster-name-expression: new String("default")
-
combine-host-port: true
-
instanceUrlSuffix: /actuator/hystrix.stream #turbine默认监控actuator/路径下的端点,修改直接监控hystrix.stream
-
#cluster-name-expression: metadata['cluster']
-
#aggregator:
-
# cluster-config: ribbon
-
#instanceUrlSuffix: /hystrix.stream #turbine默认监控actuator/路径下的端点,修改直接监控hystrix.stream
(4)启动类
-
package com.abc.consumer;
-
-
import org.springframework.boot.SpringApplication;
-
import org.springframework.boot.autoconfigure.SpringBootApplication;
-
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
-
import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard;
-
import org.springframework.cloud.netflix.turbine.EnableTurbine;
-
-
-
@SpringBootApplication
-
@EnableTurbine
-
@EnableHystrixDashboard
-
@EnableEurekaClient
-
public class MonitorApplication {
-
-
public static void main(String[] args) {
-
SpringApplication.run(MonitorApplication.class, args);
-
}
-
-
/*@Bean
-
public ServletRegistrationBean getServlet() {
-
HystrixMetricsStreamServlet streamServlet = new HystrixMetricsStreamServlet();
-
ServletRegistrationBean registrationBean = new ServletRegistrationBean(streamServlet);
-
registrationBean.setLoadOnStartup(1);
-
registrationBean.addUrlMappings("/actuator/hystrix.stream);
-
registrationBean.setName("HystrixMetricsStreamServlet");
-
return registrationBean;
-
}*/
-
-
}
七、启动
(1)启动eureka模块
(2)启动两个消费者模块
(3)启动turbine监控模块
八、效果
(1)请求http://localhost:8080/consumer/depart/get/1

(1)请求http://localhost:8081/consumer/depart/get/1

浏览器访问http://localhost:9000/hystrix
输入http://localhost:9000/turbine.stream


其他说明
图片说明借鉴 https://www.jianshu.com/p/590bad4c8947
Turbine使用的更多相关文章
- 第二十六章 hystrix-dashboard + turbine
一.使用turbine的意义 引入多个hystrix stream: 1.使用hystrix-dashboard的可以添加多个stream的功能 图中添加的两个stream会在真正monitor的时候 ...
- 附7 turbine
一.作用 聚集同一个微服务的相同的commandKey.Threadpool.commandGroupKey数据进行聚合 二.配置 1.集群(cluster)(turbine聚集数据的粒度) turb ...
- apache开源项目-- Turbine
1.缘起 Jetspeed是Apache Jakarta小组的开放源码门户系统.它使得最终用户可以通过WAP手机.浏览器.PDA等各种设备来使用各种各样的网络资源(比如应用程序.数据以及这之外的任何网 ...
- springcloud(五):熔断监控Hystrix Dashboard和Turbine
Hystrix-dashboard是一款针对Hystrix进行实时监控的工具,通过Hystrix Dashboard我们可以在直观地看到各Hystrix Command的请求响应时间, 请求成功率等数 ...
- spring cloud熔断监控Hystrix Dashboard和Turbine
参考: http://blog.csdn.net/ityouknow/article/details/72625646 完整pom <?xml version="1.0" e ...
- 改造断路器集群监控Hystrix Turbine实现自动注册消费者、实时监控多个服务
在上一篇文章中,我们搭建了Hystrix Dashoard,对指定接口进行监控.但是只能对一个接口进行监听,功能比较局限: Turbine:汇总系统内多个服务的数据并显示到 Hystrix Dashb ...
- spring cloud(五)熔断监控Hystrix Dashboard和Turbine
Hystrix-dashboard是一款针对Hystrix进行实时监控的工具,通过Hystrix Dashboard我们可以在直观地看到各Hystrix Command的请求响应时间, 请求成功率等数 ...
- Spring Cloud Turbine微服务集群实时监控
本文代码下载地址: https://gitlab.com/mySpringCloud/turbine SpringBoot版本:1.5.9.RELEASE (稳定版) SpringCloud版本:Ed ...
- SpringCloud系列七:Hystrix 熔断机制(Hystrix基本配置、服务降级、HystrixDashboard服务监控、Turbine聚合监控)
1.概念:Hystrix 熔断机制 2.具体内容 所谓的熔断机制和日常生活中见到电路保险丝是非常相似的,当出现了问题之后,保险丝会自动烧断,以保护我们的电器, 那么如果换到了程序之中呢? 当现在服务的 ...
- Spring Cloud 入门教程(八): 断路器指标数据监控Hystrix Dashboard 和 Turbine
1. Hystrix Dashboard (断路器:hystrix 仪表盘) Hystrix一个很重要的功能是,可以通过HystrixCommand收集相关数据指标. Hystrix Dashboa ...
随机推荐
- PTA 列车调度 (25分)
PTA 列车调度 (25分) [程序实现] #include<bits/stdc++.h> using namespace std; int main(){ int num,n; cin& ...
- WebJar的打包和使用
前言 WebJar官网:https://www.webjars.org/,对于任何与Servlet 3兼容的容器,WEB-INF/lib目录中的webjar都会自动作为静态资源提供.这是因为WEB-I ...
- 大爽Python入门教程 0-1 安装python
大爽Python入门公开课教案 点击查看教程总目录 一 如何找到下载地址并下载 下面展示找到下载地址的方法步骤 嫌步骤太慢可直接跳到第4步, 查看详细下载地址 使用搜索引擎搜索python 打开搜索结 ...
- SpringCloud升级之路2020.0.x版-36. 验证断路器正确性
本系列代码地址:https://github.com/JoJoTec/spring-cloud-parent 上一节我们通过单元测试验证了线程隔离的正确性,这一节我们来验证我们断路器的正确性,主要包括 ...
- [loj3272]汉堡肉
当$k\le 3$,这是一个经典的问题 设所有矩形左下角横纵坐标的最大值为$(x_{1},y_{1})$,右上角横纵坐标的最小值为$(x_{2},y_{2})$,那么必然存在一组合法解满足其中一点为$ ...
- 二、JAVA API实现HDFS
目录 前文 hdfsdemo通过HDFS上传下载文件 windows环境下需要使用uitls.exe 为pom.xml增加依赖 新建java文件HDFS_CRUD GitHub下载地址 前文 一.Ce ...
- 1、使用ValueOperations操作redis(String字符串)
文章来源:https://www.cnblogs.com/shiguotao-com/p/10559997.html 方法 c参数 s说明 void set(K key, V value); ke ...
- JavaScript 函数声明和变量声明
声明语句:声明语句是用来声明或定义标识符(变量和函数名)并给其赋值. 1:var 变量声明(5.3.1节): var语句用来声明一个或多个变量:var name_1 = [= value_1] [ , ...
- C#中的异步
什么是异步? 作为一名Web端的码农,第一次接触异步是Ajax. 异步请求后端获取数据源,js操作html的dom节点,而无需要渲染整个网页的操作. 页面上点击按钮,加载进度动画,同时发起Ajax请求 ...
- Vue 中 $on $once $off $emit 详细分析,以及使用
vue的 $on,$emit,$off,$once Api 中的解释: $on(eventName:string|Array, callback) 监听事件 监听当前实例上的自定义事件.事件可以由 v ...