首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【愚公系列】2023年11月 Java教学课程 193-SpringCloud(Hystrix服务监控)

【愚公系列】2023年11月 Java教学课程 193-SpringCloud(Hystrix服务监控)

作者头像
愚公搬代码
发布2025-06-02 14:48:59
发布2025-06-02 14:48:59
8800
代码可运行
举报
文章被收录于专栏:历史专栏历史专栏
运行总次数:0
代码可运行

🚀前言

微服务架构中的服务监控是非常重要的一环,它可以帮助我们保持系统的稳定性、可用性和性能。服务监控主要包括以下几个方面:

  1. 健康检查:每个微服务都需要提供一个健康检查接口,用于检查其是否正常运行。通常可以通过HTTP请求或者TCP连接来检查服务的健康状态。
  2. 日志监控:日志监控能够帮助我们实时监控日志信息,以便及时发现系统中的异常情况。通常采用ELK等日志收集和分析系统来实现。
  3. 指标监控:指标监控是实时监控系统各种性能指标的一种方式,可以帮助我们及时发现系统中的性能瓶颈和问题。常用的指标包括CPU使用率、内存使用率、网络IO等。
  4. 追踪监控:追踪监控是一种跟踪系统请求执行过程的监控方式,可以用于找出请求执行过程中的瓶颈和问题。通常采用Jaeger等分布式追踪系统来实现。

服务监控是微服务架构中非常重要的一环,我们需要对各个微服务进行全面的监控,以保证系统的稳定性、可用性和性能。

🚀一、Hystrix服务监控

Hystrix 是 Netflix 开源的一个高可用的熔断器实现,它可以自动地监控调用链路中的各个微服务之间的异常情况,一旦发生异常情况,Hystrix 会自动地熔断该微服务调用,防止该调用继续扩散到整个应用程序中。Hystrix 提供了一些监控指标,可以帮助开发人员了解应用程序的运行情况,例如:

  1. 请求的总数、失败数、成功数等;
  2. 熔断器状态,包括开关状态、熔断时间等;
  3. 每个服务的健康状况,包括响应时间、QPS 等。

Hystrix 还提供了一个可视化的监控仪表板,可以在 web 界面上直观地查看应用程序的运行情况,并且可以方便地进行调试和故障排查。通过 Hystrix 的监控和熔断功能,可以大大提高应用程序的可用性和容错性,确保应用程序的稳定运行。

Turbine 可以将多个 Hystrix-dashboard 实例的监控数据聚合起来,方便进行统一的监控和管理。通过配置 Turbine 与 Eureka 注册中心的连接,可以自动发现并收集所有微服务实例的监控数据,然后在 Turbine 的监控面板上进行展示和分析。这样就可以方便的进行微服务整体的监控和管理了。

🔎1.Turbine聚合监控

🦋1.1 搭建监控模块

1. 创建监控模块

创建hystrix-monitor模块,使用Turbine聚合监控多个Hystrix dashboard功能,

2. 引入Turbine聚合监控起步依赖

在 Spring Boot 项目中,需要在 pom.xml 文件中引入 Turbine 和 Hystrix Dashboard 的依赖,比如:

代码语言:javascript
代码运行次数:0
运行
复制
<?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">
    <parent>
        <artifactId>hystrix-parent</artifactId>
        <groupId>com.itheima</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>hystrix-monitor</artifactId>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

        <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-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

3. 修改application.yml

在 Spring Boot 项目中,需要在 pom.xml 文件中引入 Turbine 和 Hystrix Dashboard 的依赖,比如:

代码语言:javascript
代码运行次数:0
运行
复制
spring:
  application.name: hystrix-monitor
server:
  port: 8769
turbine:
  combine-host-port: true
  # 配置需要监控的服务名称列表
  app-config: hystrix-provider,hystrix-consumer
  cluster-name-expression: "'default'"
  aggregator:
    cluster-config: default
  #instanceUrlSuffix: /actuator/hystrix.stream
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/

其中,clusterConfig 和 clusterNameExpression 表示聚合多个 Hystrix Dashboard 的配置信息。appConfig 表示要聚合的 Hystrix Dashboard 的应用名称列表。instanceUrlSuffix 表示 Hystrix Dashboard 的监控数据 URL 后缀。在这个示例中,turbine 服务会聚合名为 hystrix-provider、hystrix-consumer 的二个微服务的 Hystrix Dashboard 数据,并将聚合后的数据注册到 Eureka 服务器中。

4. 创建启动类

在 Spring Boot 项目中,需要在 pom.xml 文件中引入 Turbine 和 Hystrix Dashboard 的依赖,比如:

代码语言:javascript
代码运行次数:0
运行
复制
@SpringBootApplication
@EnableEurekaClient

@EnableTurbine //开启Turbine 很聚合监控功能
@EnableHystrixDashboard //开启Hystrix仪表盘监控功能
public class HystrixMonitorApp {

    public static void main(String[] args) {
        SpringApplication.run(HystrixMonitorApp.class, args);
    }

}
🦋1.2 修改被监控模块

需要分别修改 hystrix-provider 和 hystrix-consumer 模块:

1、导入依赖:

代码语言:javascript
代码运行次数:0
运行
复制
<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>

2、配置Bean

此处为了方便,将其配置在启动类中。

代码语言:javascript
代码运行次数:0
运行
复制
@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;
    }

3、启动类上添加注解@EnableHystrixDashboard

代码语言:javascript
代码运行次数:0
运行
复制
@EnableDiscoveryClient
@EnableEurekaClient
@SpringBootApplication
@EnableFeignClients 
@EnableHystrixDashboard // 开启Hystrix仪表盘监控功能
public class ConsumerApp {


    public static void main(String[] args) {
        SpringApplication.run(ConsumerApp.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.3 启动测试

在浏览器访问http://localhost:8769/hystrix/ 进入Hystrix Dashboard界面

界面中输入监控的Url地址 http://localhost:8769/turbine.stream,监控时间间隔2000毫秒和title,如下图

  • 实心圆:它有颜色和大小之分,分别代表实例的监控程度和流量大小。如上图所示,它的健康度从绿色、黄色、橙色、红色递减。通过该实心圆的展示,我们就可以在大量的实例中快速的发现故障实例和高压力实例。
  • 曲线:用来记录 2 分钟内流量的相对变化,我们可以通过它来观察到流量的上升和下降趋势。

🚀感谢:给读者的一封信

亲爱的读者,

我在这篇文章中投入了大量的心血和时间,希望为您提供有价值的内容。这篇文章包含了深入的研究和个人经验,我相信这些信息对您非常有帮助。

如果您觉得这篇文章对您有所帮助,我诚恳地请求您考虑赞赏1元钱的支持。这个金额不会对您的财务状况造成负担,但它会对我继续创作高质量的内容产生积极的影响。

我之所以写这篇文章,是因为我热爱分享有用的知识和见解。您的支持将帮助我继续这个使命,也鼓励我花更多的时间和精力创作更多有价值的内容。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-05-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 🚀前言
  • 🚀一、Hystrix服务监控
    • 🔎1.Turbine聚合监控
      • 🦋1.1 搭建监控模块
      • 🦋1.2 修改被监控模块
      • 🦋1.3 启动测试
  • 🚀感谢:给读者的一封信
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档