前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringCloud-Hystrix【Feign处理降级】

SpringCloud-Hystrix【Feign处理降级】

作者头像
用户4919348
发布2019-06-13 20:47:15
1.4K0
发布2019-06-13 20:47:15
举报
文章被收录于专栏:波波烤鸭波波烤鸭

  本文我们来介绍下在使用Feign来做服务调用的情况下怎么通过Hystrix实现服务降级处理。

Feign实现服务降级

1.创建项目

  使用feign做服务调用时,provider和consumer需要依赖相同的service服务,本文仅仅创建consumer服务,其他相关服务参考git案例:https://github.com/q279583842q/SpringCloud-dpb-Demo

在这里插入图片描述
在这里插入图片描述

2.修改配置文件

  feign中默认是关闭对Hystrix的支持的,我们需要放开设置

代码语言:javascript
复制
spring.application.name=shop-product-consumer-hystrix
server.port=9090
#设置服务注册中心地址,指向另一个注册中心
eureka.client.serviceUrl.defaultZone=http://dpb:123456@eureka1:8761/eureka/,http://dpb:123456@eureka2:8761/eureka/

#Feign 默认是不开启 Hystrix 的。默认为:false
feign.hystrix.enabled=true

3.业务处理

  业务层接口中我们不需要再继承自service中的父接口了,直接在接口中声明一模一样的方法接口

代码语言:javascript
复制
/**
 * feign 做服务降级处理
 *    不需要继承 ProductService接口
 * fallback属性关联托底数据类
 */
@FeignClient(name="shop-product-provider" )
public interface ProductConsumerService  {

    @RequestMapping(value="/product/findAll",method= RequestMethod.GET)
    public List<Product> findAll();

}

添加返回托底数据的类

代码语言:javascript
复制
/**
 * @program: springcloud-feign-prodcut-consumer-hystrix
 * @description: fallback类
 * @author: 波波烤鸭
 * @create: 2019-06-12 21:35
 */
 @Component
public class ProductServiceFallback implements ProductConsumerService {
    /**
     * 能够返回托底数据的 fallback 方法
     * @return
     */
    @Override
    public List<Product> findAll() {

        List<Product> list = new ArrayList<>();
        list.add(new Product(-1, "我是托底数据"));
        return list;
    }
}
在这里插入图片描述
在这里插入图片描述

在service接口中关联托底数据

在这里插入图片描述
在这里插入图片描述

4.测试

  分别启动provider和consumer服务,正常访问

在这里插入图片描述
在这里插入图片描述

关闭provider,然后访问,获取到了托底数据,降级成功

在这里插入图片描述
在这里插入图片描述
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年06月12日,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Feign实现服务降级
    • 1.创建项目
      • 2.修改配置文件
        • 3.业务处理
          • 4.测试
          相关产品与服务
          微服务引擎 TSE
          微服务引擎(Tencent Cloud Service Engine)提供开箱即用的云上全场景微服务解决方案。支持开源增强的云原生注册配置中心(Zookeeper、Nacos 和 Apollo),北极星网格(腾讯自研并开源的 PolarisMesh)、云原生 API 网关(Kong)以及微服务应用托管的弹性微服务平台。微服务引擎完全兼容开源版本的使用方式,在功能、可用性和可运维性等多个方面进行增强。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档