Spring Cloud 之 Feign.

来源:https://www.cnblogs.com/jmcui/archive/2019/07/20/11218824.html
-Advertisement-
Play Games

一、概述  前面的文章中提到,如果我們要調用其它應用的服務,只能夠通過 RestTemplate 的方式,這在我們實際的開發中很不方便。那麼有沒有類似於 Dubbo 中 @Reference 這樣的註解直接調用呢?這就是我們今天要講的 Spring Cloud Feign。  S ...


一、概述

 前面的文章中提到,如果我們要調用其它應用的服務,只能夠通過 RestTemplate 的方式,這在我們實際的開發中很不方便。那麼有沒有類似於 Dubbo 中 @Reference 這樣的註解直接調用呢?這就是我們今天要講的 Spring Cloud Feign。

 Spring Cloud Feign 基於 Netflix Feign 實現,整合了 Spring Cloud Ribbon 與 Spring Cloud Hystrix,除了提供這兩者的強大功能之外,它還提供了一種聲明式的 Web 服務客戶端定義方式。

 Spring Cloud Feign 具備可插拔的註解支持,包括 Feign 註解和 JAX-RS 註解。同時,為了適應 Spring 的廣大用戶,它在 Netflix Feign 的基礎上擴展了對 Spring MVC 的註解支持。

二、Feign 實戰

SpringBoot 版本號:2.1.6.RELEASE
SpringCloud 版本號:Greenwich.RELEASE

1. pom.xml

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
    </dependencies>

2. application.yml

server:
  port: 2032

spring:
  application:
    name: cloud-feign-consumer


eureka:
  client:
    service-url:
      defaultZone: http://user:password@localhost:1111/eureka/

3. FeignApplication.java

// 開啟 Spring Cloud Feign 的支持功能
@EnableFeignClients
@EnableDiscoveryClient
@SpringBootApplication
public class FeignApplication {

    public static void main(String[] args) {
        SpringApplication.run(FeignApplication.class, args);
    }
}

4. 介面定義

@FeignClient(value = "cloud-eureka-client")
public interface FeignService {

    @RequestMapping("/hello")
    String hello();
}

這裡我們定義了一個介面(方法名和註解與服務提供方一致),並通過 @FeignClient 註解綁定到服務提供方。當調用 FeignService.hello() 的時候,Feign 會把請求包裝成 "http://cloud-eureka-client/hello" 的樣子,通過 RestTemplate 調用並返回結果。

對於 Spring Cloud Feign 的參數綁定,就是當調用方法需要有參數的時候,參數格式只需按照 Spring MVC 的註解即可。區別是:在定義各參數綁定時,@RequestParam、@RequestHeader 等可以指定參數名稱的註解,它們的 value 千萬不能少。在 SpringMVC 程式中,這些註解會根據參數名來作為預設值,但是在 Feign 中綁定參數必須通過 value 屬性來指明具體的參數名。

對於在服務提供方和服務調用方都維護一份介面定義的做法著實不提倡,原因很簡單,修改了一個方法,需要同時在兩個地方做出改變。比較好的做法是:服務提供方暴露一個 xxx-interface 的 jar 包供服務調用方引用。這樣,服務調用方,直接引用 xxx-interface 的方法,不維護介面定義,不關心實現。

5. Spring Cloud Feign 中的 Ribbon 配置

由於 Spring Cloud Feign 的客戶端負載均衡是通過 Spring Cloud Ribbon 實現的,所以我們可以直接通過配置 Ribbon 客戶端的方式來定義各個服務客戶端調用的參數。

# 全局配置
ribbon:
  # 連接超時時間
  ConnectTimeout: 500
  # 調用超時時間
  ReadTimeout: 2000

# 針對單個服務的 Ribbon 配置
cloud-eureka-client:
  ribbon:
    # 重試次數
    MaxAutoRetries: 2

我們需要讓 Hystrix 的超時時間大於 Ribbon 的超時時間,否則 Hystrix 命令超時後,該命令直接熔斷,重試機制就沒有任何意義了。

配置參數可以在 CommonClientConfigKey.java 中查詢到,具體每個參數的含義,就不在這裡細講了。

6. Spring Cloud Feign 中的 Hystrix 配置

預設情況下,Spring Cloud Feign 會為將所有 Feign 客戶端的方法都封裝到 Hystrix 命令中進行服務保護。當然,可以在配置文件中選擇開啟或者關閉 Hystrix:

feign:
  hystrix:
    enabled: true

如果我們僅要在某個服務中關閉 Hystrix 呢?那麼我們就要自定義一個配置類了:

@Configuration
public class DisableHystrixConfig {

    @Bean
    @Scope(ConfigurableBeanFactory.SCOPE_PROTOTYPE)
    public Feign.Builder feignBuilder() {
        return new Feign.Builder();
    }

}

然後再 @FeignClient 註解中引用:

@FeignClient(value = "cloud-eureka-client", configuration = DisableHystrixConfig.class)

上一篇文章 我們看到 Hystrix 中有很多的配置參數,那麼在 Feign 中如何配置它們呢?

# 配置全局的超時時間
hystrix:
  command:
    default:
      execution:
        isolation:
          thread:
            timeoutinMilliseconds: 5000

    # 針對某個 commandKey 做配置,而 commandKey 預設取得是客戶端中的方法名作為標識。所以如果存在相同方法名會共用配置。
    hello:
      execution:
        isolation:
          thread:
            timeoutinMilliseconds: 5000

Hystrix 的配置參數可以在 HystrixCommandProperties.java 中找到。

7. 服務降級

在 Hystrix 中服務降級我們通過 fallbackMethod 來實現,那麼 Feign 中沒法直接使用 @HystrixCommand 註解,要怎麼配置服務降級呢?首先。我們要實現一個需要降級的介面,並提供降級實現:

@Component
public class FeignServiceFallback implements FeignService {

    @Override
    public String hello() {
        return "error";
    }
}

然後再 @FeignClient 註解中引用:

@FeignClient(value = "cloud-eureka-client", configuration = DisableHystrixConfig.class, fallback = FeignServiceFallback.class)

8. 日誌配置

Spring Cloud Feign 在構建被 @FeignClient 註解修飾的服務客戶端時,會為每一個客戶端都創建一個 Logger.Level 實例,我們可以利用該日誌對象的 DEBUG 模式來幫助分析 Feign 的請求細節。

    @Bean
    public Logger.Level feignLoggerLevel() {
        return Logger.Level.BASIC;
    }

Logger.Level 有四種級別:

  • NONE: 不記錄任何信息。
  • BASIC: 僅記錄請求方法、URL以及響應狀態碼和執行時間。
  • HEADERS: 除了記錄 BASIC 級別的信息之外,還會記錄請求和響應的頭信息。
  • FULL: 記錄所有請求與響應的明細,包括頭信息、請求體、元數據等。

tips:該配置項只有 Spring 的日誌級別為 Debug 時才生效。

9. 其他配置

Spring Cloud Feign 支持對請求與響應進行 GZIP 壓縮,以減少通信過程中的性能損耗。

feign:
  compression:
    # 開啟請求和響應的壓縮功能
    request:
      enabled: true
      # 超過 2M 才開始壓縮
      min-request-size: 2048
      # 壓縮類型
      mime-types: {"text/xml", "application/xml", "application/json"}
    response:
      enabled: true

演示源代碼 :https://github.com/JMCuixy/spring-cloud-demo

內容參考:《Spring Cloud 微服務實戰》


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 下載地址 下載地址 ...
  • # list 列表 # 中括弧括起來,逗號分隔每個元素, # 列表中可以是數字字元串、列表等都可以放進去 list1 = [123, "book", "手動", ["data", 123, "文件"], 232, "tool", 'age', True] # list提供的方法 # 1 索引取值 p... ...
  • 題目鏈接:https://www.luogu.org/problemnew/show/P1330 思路:參考過大佬的思路,第一次用染色思想寫題。提取題目的關鍵: (1)一條邊相連的點只至少有一個被占領。 (2)相鄰兩個點不能都被占領。 (1) + (2) ——> (3)相鄰兩個點有且只有一個點要被占 ...
  • 1、settings.INSTALLED_APPS下添加:django.contrib.staticfiles 2、settings.py下添加:STATIC_URL = '/static/' 3、 (1)在APP下新建文件夾static,然後在這個static文件夾下創建一個當前APP的名字的文件... ...
  •   Java虛擬機採用可達性分析演算法來判斷對象是否可以回收。可達性分析演算法通過一系列的GC Roots對象作為起始點,向下搜索走過的路徑稱引用鏈,當一個對象到GC Roots沒有任何的引用鏈時,證明對象是不可用的。 Java中,可作為GC Roots的對象: 虛擬機棧中引用的對象 ...
  • 第五章 簡單搜索 眾里尋他千百度 搜索是ES的核心,本節講解一些基本的簡單的搜索。 掌握ES搜索查詢的RESTful的API猶如掌握關係型資料庫的SQL語句,儘管Java客戶端API為我們不需要我們去實際編寫RESTful的API,但在生產環境中,免不了線上上執行查詢語句做數據統計供產品經理等使用。 ...
  • Spring中的JdbcTemplate JdbcTemplate:他是spring框架中提供的一個對象,是對原始Jdbc API對象的簡單封裝。 JdbcTemplate的作用:用於和資料庫交互的,實現對錶的CRUD操作 JdbcTemplate的入門 導入相關的坐標 賬戶實體類的建立 操作資料庫 ...
  • 1.學生類的使用: 結果: 2.手機類的使用: 結果: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...