SpringCloud学习(八)--消费者服务基于Hystrix实现容错处理与监控(Feign客户端服务)

本文介绍Feign客户端如何使用Hystrix实现服务降级,包括两种实现方式:通过@FeignClient注解的fallback属性和fallbackFactory属性。同时,文章还讲解了如何配置Feign以启用Hystrix组件,并通过Actuator和Hystrix的依赖实现Feign的监控。
摘要由CSDN通过智能技术生成

非Feign客户端消费者服务在使用Hystrix时,仅需要在指定方法上声明注解@HystrixCommand,并通过fallbackMethod属性指定服务降级处理方法即可.然而,Feign客户端消费者服务是以接口的形式进行服务消费的,其接口方法并不存在方法体,所以相对于非Feign客户端的消费者服务来说,Feign实现Hystrix另有方案.其实,Feign已经整合了Hystrix组件,需要手动开启方可使用.


Feign开启Hystrix组件

在application.yml文件中,feign: hystrix: enabled: true -->开启hystrix组件 


Feign使用Hystrix实现服务降级方式一:@FeignClient注解fallback属性实现

 服务降级指定好后,启动eureka和fegin客户端服务.

 然后在浏览器上输入 http://localhost:8181/user/2 进行测试.由于Feign接口获取不到生产者实例,所以会执行服务降级方法.

 以上,便通过@FeignClient的属性fallback实现了服务的降级处理.


Feign使用Hystrix实现服务降级方式二:@FeignClient注解fallbackFactory属性实现

 ①很多场景下,需要了解服务降级的原因,那么就可以使用@FeignClient的fallbackFactroy属性实现服务降级,以便满足要求.

创建一个UserFeignClientFallbackFactory类并实现泛型为UserFeignClient的FallbackFactory接口,

并重写FallbackFactory接口的create(Throwable throwable)方法,输出throwable对象即可查看服务降级处理的原因.

@FeignClient注解使用fallbackFactroy属性指定服务降级处理类即可

 然后在浏览器上输入 http://localhost:8181/user/2 进行测试.由于Feign接口获取不到生产者实例,所以会执行服务降级方法.

 Run Dashboard控制台端输出如下

2020-09-16 16:52:33.895  INFO 3260 --- [loud-provider-1] c.g.c.f.UserFeignClientFallbackFactory   : 服务降级处理原因:java.lang.RuntimeException: com.netflix.client.ClientException: Load balancer does not have available server for client: springcloud-provider

 以上,便通过@FeignClient的属性fallbackFactory实现了服务的降级处理.

如果需要让不同的异常返回不同的处理结果时,可以通过throwable对象的类型判断即可.


 Hystrix监控Feign

 引入Actuator和Hystrix的依赖

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

启动类声明@EnableHystrix注解,开启对/actuator/hystrix.stream端点的支持

application.yml配置actuator端点暴露(SpringBoot2.0版本需要手动配置)

然后启动项目,在浏览器输入地址 http://localhost:8182/actuator/hystrix.stream

此时,访问地址http://localhost:8182/user/2,让feign服务执行一次服务降级方法.

再次在浏览器输入地址 http://localhost:8182/actuator/hystrix.stream

由此可知,Feign已实现被Hystrix监控.同样的,Feign可以拓展使用Hystrix Dashboard进行监控,方便直观的查看信息.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值