国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

Spring Cloud 系列之服務(wù)調(diào)用 OpenFeign的實(shí)現(xiàn)

瀏覽:2日期:2023-08-04 08:59:07

1.1 簡介

1.1.1 概述

  Feign 旨在使編寫 Java Http 客戶端變得更容易。在使用 Ribbon + RestTemplate 時(shí),利用 RestTemplate 對(duì) http 請(qǐng)求的封裝處理,形成了一套模版化的調(diào)用方法。但是在實(shí)際開發(fā)中,由于對(duì)服務(wù)依賴的調(diào)用可能不止一處,往往一個(gè)接口會(huì)被多處調(diào)用,所以通常都會(huì)針對(duì)每個(gè)微服務(wù)自行封裝一些客戶端類來包裝這些依賴服務(wù)的調(diào)用。所以,F(xiàn)eign 在 Ribbon 基礎(chǔ)上做了進(jìn)一步封裝,由他來幫助我們定義和實(shí)現(xiàn)依賴服務(wù)接口的定義。在 Feign 的實(shí)現(xiàn)下,我們只需創(chuàng)建一個(gè)接口并使用注解的方式來配置它,即可完成對(duì)服務(wù)提供方的接口綁定,簡化了使用 Spring cloud Ribbon 時(shí),自動(dòng)封裝服務(wù)調(diào)用客戶端的開發(fā)量。與 Ribbon 不同的是,通過 Feign 只需要定義服務(wù)綁定接口且以聲明式的方法,優(yōu)雅而簡單的實(shí)現(xiàn)了服務(wù)調(diào)用  Feign 已經(jīng)停止維護(hù),OpenFeign 是 Spring Cloud 在 Feign 的基礎(chǔ)上進(jìn)一步開發(fā)出來替代 Feign 的技術(shù),支持了 SpringMVC 的注解,如 @RequesMapping 等等。OpenFeign 的 @FeignClient 可以解析 SpringMVC 的 @RequestMapping 注解下的接口,并通過動(dòng)態(tài)代理的方式產(chǎn)生實(shí)現(xiàn)類,實(shí)現(xiàn)類中做負(fù)載均衡并調(diào)用其他服務(wù)。

1.1.2 相關(guān)依賴

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

1.2 簡單使用

1.2.1 基礎(chǔ)工程

☞ eureka 項(xiàng)目

1.2.2 Feign 客戶端

/** * Created with IntelliJ IDEA. * * @author Demo_Null * @date 2020/11/5 * @description Feign 接口 */@Component@FeignClient('ProviderServer')// 服務(wù)提者名稱public interface ProviderFeign { @GetMapping('/provider/get')// 服務(wù)地址 public String get();}

1.2.3 啟動(dòng)類

@SpringBootApplication@EnableFeignClientspublic class ConsumerApplication { public static void main(String[] args) { SpringApplication.run(ConsumerApplication.class, args); }}

1.2.4 調(diào)用服務(wù)

  我們可以發(fā)現(xiàn) Feign 自帶負(fù)載均衡配置,而 OpenFeign 默認(rèn)支持 Ribbon,我們可以通過 Ribbon 的配置來修改負(fù)載均衡策略。Ribbon 詳情參考 ☞ Spring Cloud 系列之負(fù)載均衡 Ribbon

Spring Cloud 系列之服務(wù)調(diào)用 OpenFeign的實(shí)現(xiàn)

1.3 其他配置

1.3.1 超時(shí)控制

# 設(shè)置 feign 客戶端超時(shí)時(shí)間, 默認(rèn) 1sfeign: client: config: default: connectTimeout: 5000 readTimeout: 5000# OpenFeign 默認(rèn)支持 Ribbon,也可以使用以下配置ribbon: # 建立連接所用時(shí)間,適用于網(wǎng)絡(luò)正常的情況下,兩端連接所用的時(shí)間 ConnectTimeout: 5000 # 建立連接后從服務(wù)器讀取到可用資源所用的時(shí)間 ReadTimeout: 5000

1.3.2 數(shù)據(jù)壓縮

feign: compression: request: # 開啟數(shù)據(jù)壓縮請(qǐng)求 enabled: true # 壓縮數(shù)據(jù)類型 mime-types: text/xml, application/xml, application/json # 數(shù)據(jù)壓縮下限 2048表示傳輸數(shù)據(jù)大于2048 才會(huì)進(jìn)行數(shù)據(jù)壓縮(最小壓縮值標(biāo)準(zhǔn)) min-request-size: 2048 # 開啟數(shù)據(jù)壓縮響應(yīng) response: enabled: true

1.3.3 日志配置

☞ 日志級(jí)別

 ♞ NONE:不開啟日志(默認(rèn)) ♞ BASIC:記錄請(qǐng)求方法、URL、響應(yīng)狀態(tài)、執(zhí)行時(shí)間 ♞ HEADERS:在 BASIC 基礎(chǔ)上增加請(qǐng)求/響應(yīng)頭 ♞ FULL:在 HEADERS 基礎(chǔ)上增加 body 和請(qǐng)求元數(shù)據(jù)

☞ 配置類

@Configurationpublic class LogConfig { @Bean Logger.Level loggerLevel(){ return Logger.Level.FULL; }}

☞ 配置文件

logging: level: # 以什么級(jí)別監(jiān)控那個(gè)接口 com.software.controller: debug

☞ 輸出

Spring Cloud 系列之服務(wù)調(diào)用 OpenFeign的實(shí)現(xiàn)

☞ 源碼

到此這篇關(guān)于Spring Cloud 系列之服務(wù)調(diào)用 OpenFeign的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Spring Cloud服務(wù)調(diào)用 OpenFeign內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 商都县| 慈溪市| 吉隆县| 宿松县| 出国| 宣恩县| 湟源县| 登封市| 通辽市| 三门县| 交口县| 隆尧县| 青浦区| 嵊泗县| 新和县| 宾川县| 澄迈县| 安新县| 新营市| 嘉定区| 黑水县| 顺义区| 霍山县| 台山市| 白银市| 常宁市| 湖州市| 双牌县| 炉霍县| 个旧市| 凌云县| 临江市| 长治县| 澜沧| 张家界市| 鄂伦春自治旗| 祁门县| 遵义县| 大名县| 漳州市| 宜昌市|