软件编程
位置:首页>> 软件编程>> java编程>> Spring Cloud之服务监控turbine的示例

Spring Cloud之服务监控turbine的示例

作者:冰清雪酷  发布时间:2023-04-20 23:26:44 

标签:Spring,Cloud,turbine

turbine是聚合服务器发送事件流数据的一个工具,hystrix的监控中,只能监控单个节点,实际生产中都为集群,因此可以通过turbine来监控集群下hystrix的metrics情况,通过eureka来发现hystrix服务。

新建turbine项目

TurbineApplication.java


package turbine;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.hystrix.EnableHystrix;
import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard;
import org.springframework.cloud.netflix.turbine.EnableTurbine;
/**
* Created by sai.luo on 2017/4/26.
*/
@SpringBootApplication
@EnableTurbine
@EnableHystrix
@EnableHystrixDashboard
public class TurbineApplication{
public static void main(String[] args) {
 SpringApplication.run(TurbineApplication.class,args);
}
}

pom.xml


<?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>

<artifactId>turbine</artifactId>
<properties>
 <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
 <java.version>1.8</java.version>
</properties>

<parent>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-parent</artifactId>
 <version>1.5.2.RELEASE</version>
 <relativePath/> <!-- lookup parent from repository -->
</parent>

<dependencies>
 <!-- hystrix依赖 -->
 <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>
 <!-- turnbine依赖 -->
 <dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-turbine</artifactId>
 </dependency>
</dependencies>
<dependencyManagement>
 <dependencies>
  <dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-dependencies</artifactId>
   <version>Camden.SR5</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>

application.yml


spring:
application:
name: turbine
server:
port: 8000
turbine:
app-config: hello,helloClient ##需要监控的服务名
aggregator:
clusterConfig: main ##需要监控的服务集群名
clusterNameExpression: metadata['cluster']

eureka:
instance:
preferIpAddress: true
statusPageUrlPath: /info.html
client:
serviceUrl:
 defaultZone: http://localhost:8761/eureka/

启动服务

helloserviceeureka 项目 appliation.yml 增加集群配置

更改为


spring:
application:
name: hello

server:
port: 9001

eureka:
instance:
lease-renewal-interval-in-seconds: 3
lease-expiration-duration-in-seconds: 5
metadata-map:
 cluster: main
client:
serviceUrl:
 defaultZone: http://localhost:8761/eureka/
registry-fetch-interval-seconds: 3

logging:
level:
com:
 netflix:
 eureka: OFF
 discovery: OFF

pom.xml增加hystrix依赖包


<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
</dependency>

同理ribboneureka 项目 application.yml 增加集群配置

更改后如下


spring:
application:
name: helloClient

server:
port: 20000

eureka:
instance:
lease-renewal-interval-in-seconds: 3
lease-expiration-duration-in-seconds: 5
metadata-map:
 cluster: main
client:
serviceUrl:
 defaultZone: http://localhost:8761/eureka/
registry-fetch-interval-seconds: 3

logging:
level:
com:
 netflix:
 eureka: OFF
 discovery: OFF

pom.xml增加hystrix依赖包

RibbonEurekaApplication.java 增加注解


@EnableHystrix

启动项目

访问 localhost:8000/hystrixx 可以看到页面

注: turbine只能监控hystrix服务,不是hystrix服务,不能监控,如 hello这个服务虽然配置了集群,但是没有使用hystrix,所以不会受监控。

项目地址 https://github.com/luosai001/Spring-Cloud-Sample/tree/master

来源:https://blog.csdn.net/luosai19910103/article/details/70820904

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com