温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Spring Cloud中如何使用Hystrix实现断路器

发布时间:2022-01-11 10:31:17 来源:亿速云 阅读:145 作者:iii 栏目:开发技术

这篇文章主要介绍了Spring Cloud中如何使用Hystrix实现断路器的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Spring Cloud中如何使用Hystrix实现断路器文章都会有所收获,下面我们一起来看看吧。

1. Hystrix Dashboard 监控

除了隔离依赖服务的调用以外,Hystrix 还提供了准实时的调用监控(Hystrix Dashboard),Hystrix 会持续记录所有通过 Hystrix 发起的请求的执行信息,并以统计报表和图形的形式展示给用户,包括每秒执行多少请求,有多少成功或者失败等。Spring Cloud 也提供了 Hystrix Dashboard 的整合,对监控内容转化成可视化界面。

2. 如何监控?实际落地操作

我们新建一个工程:microservice-order-consumer-hystrix-dashboard,用来完成可视化监控。端口号设置为 9002。

2.1 导入监控相关的依赖

首先要导入 dashboard 的依赖:

<dependencies>
   <!-- hystrix -->
   <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>
</dependencies>

2.2 添加启动注解

在启动类中,需要添加 @EnableHystrixDashboard 注解。

@SpringBootApplication
@EnableHystrixDashboard
public class OrderConsumerHystrixDashboard {

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

2.3 服务提供方需要添加监控依赖

在服务提供方,也需要添加一个 Spring Boot 监控依赖:

<!-- spring boot actuator 监控信息 -->
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

2.4 测试一下

OK,这样的话,hystrix dashboard 就基本配置好了,启动一下我们新建的这个监控项目,在浏览器中输入:http://localhost:9002/hystrix ,如果出现下面的这只豪猪兄,那说明 dashboard 没有问题。

Spring Cloud中如何使用Hystrix实现断路器

3. 如何来监控其他服务

OK,上面我们能正常启动豪猪兄了,但是如何监控其他服务呢?我们以带有 hystrix 的订单提供服务为例(端口号为8001)。如果要实现被监控,我们需要在被监控的服务上做一些准备。

3.1 依赖导入

首先在这个订单服务上添加 hystrix 依赖(当然了,该8001端口的订单提供服务已经添加过了该依赖了):

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

3.2 启动类注解

在启动类上添加注解:@EnableCircuitBreaker

@SpringBootApplication
@EnableEurekaClient
@MapperScan("com.itcodai.springcloud.dao")
@EnableCircuitBreaker
public class OrderProvider01 {

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

3.3 application.yml 配置文件

最后,在配置文件中开启指标流端点,这个在后面监控时候需要用到,下文再来描述。

## 开启指标流端点
management:
 endpoints:
   web:
     exposure:
       include: hystrix.stream

3.4 测试一下

万事俱备,只欠东风了,接下来我们来测试一下效果。首先:使用8001端口的订单服务为例,首先启动eureka集群,然后启动带有hsytrix的订单服务,我们在浏览器里输入 http://localhost:8001/provider/order/get/1 可以获取订单服务信息,确定订单服务正常。

然后打开 http://localhost:9002/hystrix 能出现豪猪兄,说明 dashboard 没有问题。

Spring Cloud中如何使用Hystrix实现断路器

我们看到,这个url 就是用来监控某个服务的状态,上面在application.yml文件里配置的url就是作用于此,我们新打开一个浏览器窗口,输入:http://localhost:8001/actuator/hystrix.stream,可以看到一直在刷一些信息,这些信息就是该服务相关接口的信息,但是很不直观,接下来我们看一下直观的效果。

在豪猪兄的页面输入http://localhost:8001/actuator/hystrix.stream, delay延迟设置为2000(2秒),Title自己取个名字即可。打开后即可在可视化页面监控 8001 这个端口的接口调用信息,我们调用两个接口:

http://localhost:8001/provider/order/get/1

http://localhost:8001/provider/order/get/list

多次刷新几次调用,可以看到可视化界面的一些信息,如下:

Spring Cloud中如何使用Hystrix实现断路器

从这个监控仪表盘中可以很清楚的看到服务被调用的状态

关于“Spring Cloud中如何使用Hystrix实现断路器”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Spring Cloud中如何使用Hystrix实现断路器”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI