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

非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进行监控,方便直观的查看信息.

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
[为什么要学习Spring Cloud微服务] SpringCloud作为主流微服务框架,已成为各互联网公司的首选框架,国内外企业占有率持续攀升,是Java工程师的必备技能。就连大名鼎鼎的阿里巴巴dubbo也正式更名为Spring Cloud Alibaba,成为了Spring Cloud 微服务中的一个子模块。Spring Cloud是企业架构转型、个人能力提升、架构师进阶的不二选择。 【推荐你学习这门课的理由】 1、本课程总计29课时,从微服务是什么、能够做什么开始讲起,绝对的零基础入门 2、课程附带全部26个项目源码,230页高清PDF正版课件 【课程知识梳理】 1、先讲解了什么是单体架构、什么是微服务架构、他们之间有什么区别和联系,各自有什么优缺点。 2、从本质入手,使用最简单的Spring Boot搭建微服务,让你认清微服务是一种思想和解决问题的手段,而不是新兴技术。 3、讲解Spring BootSpring Cloud 微服务架构之间的联系,原生的RestTemplate工具,以及Actuator监控端点的使用。4、带着微服务所带来的各种优缺点,为大家引入服务发现与注册的概念和原理,从而引入我们的第一个注册中心服务Eureka。5、引入负载均衡的理念,区分什么是服务端负载均衡,什么是客户端负载均衡,进而引入Ribbon负载均衡组件的详细使用。6、为了解决微服务之间复杂的调用,降低代码的复杂度,我们引入了Feign声明式客户端,让你几行代码搞定服务的远程调用。7、最后为大家介绍了整个微服务体系应该包含什么,学习路线是什么,应该学习什么。 【学习方法】 每一节课程均有代码,最好的方式是静下心来,用一天的时间,或者两个半天时间来学习。一边听我的讲解,一边使用我提供的项目代码进行观察和运行。只要你能跟住我的节奏,你就可以搞定微服务

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值