欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

spring-cloud-gateway降級的實現(xiàn)

 更新時間:2020年04月08日 08:34:29   作者:當我遇上你  
這篇文章主要介紹了spring-cloud-gateway降級的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

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

當下游接口負載很大,或者接口不通等其他原因?qū)е鲁瑫r,如果接口不熔斷的話將會影響到下游接口得不到喘息,網(wǎng)關(guān)也會因為超時連接一直掛起,很可能因為一個子系統(tǒng)的問題導(dǎo)致整個系統(tǒng)的雪崩。所以我們的網(wǎng)關(guān)需要設(shè)計熔斷,當因為熔斷器打開時,網(wǎng)關(guān)將返回一個降級的應(yīng)答。

Maven 配置

添加 hystrix 依賴

pom.xml

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

項目實戰(zhàn)

在 provider1 服務(wù)中添加一個方法,延時 2 秒返回響應(yīng)。

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

修改網(wǎng)關(guān)配置文件

server:
 port: 2000
spring:
 application:
  name: idc-gateway2
 redis:
  host: localhost
  port: 6379
  timeout: 6000ms # 連接超時時長(毫秒)
  jedis:
   pool:
    max-active: 1000 # 連接池最大連接數(shù)(使用負值表示沒有限制)
    max-wait: -1ms   # 連接池最大阻塞等待時間(使用負值表示沒有限制)
    max-idle: 10   # 連接池中的最大空閑連接
    min-idle: 5    # 連接池中的最小空閑連接
 cloud:
  consul:
   host: localhost
   port: 8500
  gateway:
   discovery:
    locator:
     enabled: true # gateway可以通過開啟以下配置來打開根據(jù)服務(wù)的serviceId來匹配路由,默認是大寫
   routes:
    - id: provider1
     uri: lb://idc-provider1
     predicates:
      - Path=/p1/**
     filters:
      - StripPrefix=1
      - name: Hystrix
       args:
        name: default
        fallbackUri: forward:/defaultfallback # 只有該id下的服務(wù)會降級
    - 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

網(wǎng)關(guān)添加降級處理類

@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","服務(wù)超時降級");
map.put("data",null);
return map;
}
}

降級測試

超時服務(wù)降級

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

返回

{"msg":"服務(wù)超時降級","code":200,"data":null}

其他異常

spring-cloud-gateway 調(diào)用下游服務(wù)返回的異常,網(wǎng)關(guān)不做任何處理,會直接返回。大家想一下為什么在網(wǎng)關(guān)不去處理下游異常呢? 因為很多時候下游的異常是包含有效信息的(異常信息千千萬),如果在網(wǎng)關(guān)處做了統(tǒng)一返回,就失去了返回異常的意義。

spring-cloud-starter-netflix-hystrix 內(nèi)置的 Hystrix 過濾器是
HystrixGatewayFilterFactory。 感興趣的小伙伴可以自行閱讀相關(guān)源碼。

到此這篇關(guān)于spring-cloud-gateway降級的實現(xiàn)的文章就介紹到這了,更多相關(guān)spring-cloud-gateway降級 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java程序包不存在的兩種解決方法

    Java程序包不存在的兩種解決方法

    有時候我們在導(dǎo)入程序之后,系統(tǒng)會給出錯誤提示:Java:程序包xxxx不存在,本文主要介紹了Java程序包不存在的兩種解決方法,具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • java實現(xiàn)上傳圖片并壓縮圖片大小功能

    java實現(xiàn)上傳圖片并壓縮圖片大小功能

    這篇文章主要為大家詳細介紹了java實現(xiàn)上傳圖片并壓縮圖片大小功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 使用Spring的注解方式實現(xiàn)AOP實例

    使用Spring的注解方式實現(xiàn)AOP實例

    本篇文章主要介紹了使用Spring的注解方式實現(xiàn)AOP實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • Java?生成透明圖片的設(shè)置實現(xiàn)demo

    Java?生成透明圖片的設(shè)置實現(xiàn)demo

    這篇文章主要為大家介紹了Java?生成透明圖片的設(shè)置實現(xiàn)demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • java隨機生成字符串(字符隨機生成類 生成隨機字符組合)

    java隨機生成字符串(字符隨機生成類 生成隨機字符組合)

    java隨機生成字符串,字符組合多樣,可以大小字組合、大+小字符+數(shù)字等方式,大家參考使用吧
    2013-12-12
  • JDBC連接SQL?Server數(shù)據(jù)庫實現(xiàn)增刪改查的全過程

    JDBC連接SQL?Server數(shù)據(jù)庫實現(xiàn)增刪改查的全過程

    實際開發(fā)中手動的輸入SQL語句是少之又少,大多數(shù)情況下是通過編譯代碼進行來控制自動執(zhí)行,下面這篇文章主要給大家介紹了關(guān)于JDBC連接SQL?Server數(shù)據(jù)庫實現(xiàn)增刪改查的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • 詳解SpringMVC攔截器配置及使用方法

    詳解SpringMVC攔截器配置及使用方法

    本篇文章主要介紹了SpringMVC攔截器配置及使用方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • java實現(xiàn)多設(shè)備同時登錄或強制下線

    java實現(xiàn)多設(shè)備同時登錄或強制下線

    本文主要介紹了java實現(xiàn)多設(shè)備同時登錄或強制下線,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-07-07
  • SpringSecurity-2.7中跨域問題解析

    SpringSecurity-2.7中跨域問題解析

    這篇文章主要介紹了SpringSecurity-2.7中跨域問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-01-01
  • Java InputStream的多種使用詳解

    Java InputStream的多種使用詳解

    這篇文章主要介紹了Java InputStream的多種使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12

最新評論