spring-cloud-gateway降级的实现

 更新时间:2020年04月08日 08:34:29   作者:当我遇上你  
这篇文章主要介绍了spring-cloud-gateway降级的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

本文主要研究一下 spring cloud gateway 如何集成 hystrix。

当下游接口负载很大,或者接口不通等其他原因导致超时,如果接口不熔断的话将会影响到下游接口得不到喘息,网关也会因为超时连接一直挂起,很可能因为一个子系统的问题导致整个系统的雪崩。所以我们的网关需要设计熔断,当因为熔断器打开时,网关将返回一个降级的应答。

Maven 配置

添加 hystrix 依赖

pom.xml

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

项目实战

在 provider1 服务中添加一个方法,延时 2 秒返回响应。

  @GetMapping("/timeout")
  public String timeout() {
    try {
      Thread.sleep(2000);
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
    System.out.println("休眠了2秒");
    return "timeout test";
  }

修改网关配置文件

server:
 port: 2000
spring:
 application:
  name: idc-gateway2
 redis:
  host: localhost
  port: 6379
  timeout: 6000ms # 连接超时时长(毫秒)
  jedis:
   pool:
    max-active: 1000 # 连接池最大连接数(使用负值表示没有限制)
    max-wait: -1ms   # 连接池最大阻塞等待时间(使用负值表示没有限制)
    max-idle: 10   # 连接池中的最大空闲连接
    min-idle: 5    # 连接池中的最小空闲连接
 cloud:
  consul:
   host: localhost
   port: 8500
  gateway:
   discovery:
    locator:
     enabled: true # gateway可以通过开启以下配置来打开根据服务的serviceId来匹配路由,默认是大写
   routes:
    - id: provider1
     uri: lb://idc-provider1
     predicates:
      - Path=/p1/**
     filters:
      - StripPrefix=1
      - name: Hystrix
       args:
        name: default
        fallbackUri: forward:/defaultfallback # 只有该id下的服务会降级
    - id: provider2
     uri: lb://idc-provider2
     predicates:
      - Path=/p2/**
     filters:
      - StripPrefix=1

# hystrix 信号量隔离,1.5秒后自动超时
hystrix:
 command:
  default:
   execution:
    isolation:
     strategy: SEMAPHORE
     thread:
      timeoutInMilliseconds: 1500

网关添加降级处理类

@RestController
public class FallbackController {

@RequestMapping("/defaultfallback")
public Map<String,Object> defaultfallback(){
System.out.println("降级操作...");
Map<String,Object> map = new HashMap<>();
map.put("code",200);
map.put("msg","服务超时降级");
map.put("data",null);
return map;
}
}

降级测试

超时服务降级

curl http://localhost:2000/p1/timeout

返回

{"msg":"服务超时降级","code":200,"data":null}

其他异常

spring-cloud-gateway 调用下游服务返回的异常,网关不做任何处理,会直接返回。大家想一下为什么在网关不去处理下游异常呢? 因为很多时候下游的异常是包含有效信息的(异常信息千千万),如果在网关处做了统一返回,就失去了返回异常的意义。

spring-cloud-starter-netflix-hystrix 内置的 Hystrix 过滤器是
HystrixGatewayFilterFactory。 感兴趣的小伙伴可以自行阅读相关源码。

到此这篇关于spring-cloud-gateway降级的实现的文章就介绍到这了,更多相关spring-cloud-gateway降级 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mybatisplus创建Spring Boot工程打包错误的解决方式

    Mybatisplus创建Spring Boot工程打包错误的解决方式

    最近在实战springboot遇到了一些坑,记录一下,下面这篇文章主要给大家介绍了关于Mybatisplus创建Spring Boot工程打包错误的解决方式,文中通过图文介绍的介绍的非常详细,需要的朋友可以参考下
    2023-03-03
  • java实现导出数据为zip压缩文件

    java实现导出数据为zip压缩文件

    这篇文章主要为大家详细介绍了java如何实现导出数据为zip压缩文件,并且解压后为json文件,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-11-11
  • JavaScript中的closest方法示例详解

    JavaScript中的closest方法示例详解

    这篇文章主要介绍了JavaScript中closest方法的相关资料,closest()是JavaScript中的一个非常实用的 DOM 方法,用于查找与当前元素匹配的最近的祖先元素,它支持 CSS 选择器,可以应用于事件委托、动态内容处理等场景,需要的朋友可以参考下
    2025-02-02
  • 详解Java如何使用Jsoup修改HTML元素的属性

    详解Java如何使用Jsoup修改HTML元素的属性

    Jsoup 是一个强大的 Java 库,用于解析和操作 HTML 文档,本文主要为大家介绍了如何使用Jsoup进行修改HTML元素的属性,感兴趣的可以了解下
    2025-01-01
  • Java多线程并发FutureTask使用详解

    Java多线程并发FutureTask使用详解

    Java 的多线程机制本质上能够完成两件事情,异步计算和并发,FutureTask 是基于 Runnable 实现的一个可取消的异步调用 API,本文给大家介绍Java 多线程并发FutureTask及基本使用,需要的朋友可以参考下
    2022-06-06
  • SpringBoot2学习之springboot与spring区别分析

    SpringBoot2学习之springboot与spring区别分析

    这篇文章主要为大家介绍了SpringBoot2学习之springboot与spring区别分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • Java Char的简单工具类CharUtil分享

    Java Char的简单工具类CharUtil分享

    下面小编就为大家分享一篇Java Char的简单工具类CharUtil,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-12-12
  • Java Swing组件复选框JCheckBox用法示例

    Java Swing组件复选框JCheckBox用法示例

    这篇文章主要介绍了Java Swing组件复选框JCheckBox用法,结合具体实例形式分析了Swing复选框JCheckBox简单用法与相关操作注意事项,需要的朋友可以参考下
    2017-11-11
  • 利用synchronized实现线程同步的案例讲解

    利用synchronized实现线程同步的案例讲解

    这篇文章主要介绍了利用synchronized实现线程同步的案例讲解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • Java检测线程中断状态的方法示例

    Java检测线程中断状态的方法示例

    这篇文章主要介绍了Java检测线程中断状态的方法,结合实例形式分析了java针对线程中断状态检测的相关实现技巧,需要的朋友可以参考下
    2019-10-10

最新评论