SpringCloud Feign高級配置詳解
1、Feign對負載均衡的支持
Feign 本身已經(jīng)集成了Ribbon依賴和自動配置,因此我們不需要額外引入依賴,可以通過 ribbon.xx 來進行全局配置,也可以通過服務名.ribbon.xx 來對指定服務進行細節(jié)配置配置(參考之前,此處略)
Feign默認的請求處理超時時長1s,有時候我們的業(yè)務確實執(zhí)行的需要一定時間,那么這個時候,我們就需要調整請求處理超時時長,F(xiàn)eign自己有超時設置,如果配置Ribbon的超時,則會以Ribbon的為準。
Ribbon設置
#針對的被調用方微服務名稱,不加就是全局生效
lagou-service-resume:
ribbon:
#請求連接超時時間
ConnectTimeout: 2000
#請求處理超時時間
ReadTimeout: 15000 # Feign 超時時間設置
#對所有操作都進?重試
OkToRetryOnAllOperations: true
####根據(jù)如上配置,當訪問到故障請求的時候,它會再嘗試訪問?次當前實例(次數(shù)由MaxAutoRetries配置),
####如果不?,就換?個實例進?訪問,如果還不?,再換?次實例訪問(更換次數(shù)由MaxAutoRetriesNextServer配置),
####如果依然不?,返回失敗信息。
MaxAutoRetries: 0 #對當前選中實例重試次數(shù),不包括第?次調?
MaxAutoRetriesNextServer: 0 #切換實例的重試次數(shù)
NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RoundRobinRule #負載策略調整
2、Feign對熔斷器的支持
在Feign客戶端工程配置文件(application.yml)中開啟Feign對熔斷器的支持。
# 開啟Feign的熔斷功能
feign:
hystrix:
enabled: true
Feign的超時時長設置那其實就上面Ribbon的超時時長設置,Hystrix超時設置(就按照之前Hystrix設置的方式就OK了)
注意:
- 開啟Hystrix之后,F(xiàn)eign中的方法都會被進行一個管理了,一旦出現(xiàn)問題就進入對應的回退邏輯處理
- 針對超時這一點,當前有兩個超時時間設置(Feign/hystrix),熔斷的時候是根據(jù)這兩個時間的最小值來進行的,即處理時長超過最短的那個超時時間了就熔斷進入回退降級邏輯
hystrix:
command:
default:
execution:
isolation:
thread:
timeoutInMilliseconds: 15000
自定義FallBack處理類(需要實現(xiàn)FeignClient接口)
package com.lagou.edu.controller.service; import org.springframework.stereotype.Component; /** * 降級回退邏輯需要定義一個類,實現(xiàn)FeignClient接口,實現(xiàn)接口中的方法 * 此接口是我們進行Feign遠程調用時所創(chuàng)建的接口 */ @Component public class ResumeFallback implements ResumeServiceFeignClient{ @Override public Integer findDefaultResumeState(Long userId) { return -6; } }
在@FeignClient注解中關聯(lián)2)中自定義的處理類
package com.lagou.edu.controller.service; import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; // @FeignClient標明當前類是一個Feign客戶端,value指定該客戶端要請求的服務器名稱(登記到注冊中心上服務提供者的服務名稱) @FeignClient(value = "lagou-service-resume", fallback = ResumeFallback.class, path = "/resume") // 使?fallback的時候,類上的@RequestMapping的url前綴限定,改成配置在@FeignClient的path屬性中 // @RequestMapping("/resume") public interface ResumeServiceFeignClient { // feign要做的事情,拼裝url發(fā)起請求 // 我們調用該方法就是調用本地接口方法,那么實際上做的事遠程請求 @GetMapping("/openstate/{userId}") public Integer findDefaultResumeState(@PathVariable Long userId); }
3、Feign對請求壓縮和響應壓縮的支持
Feign 支持對請求和響應進行GZIP壓縮,以減少通信過程中的性能損耗。通過下面的參數(shù)即可開啟請求與響應的壓縮功能:
feign:
compression:
request:
enabled: true # 開啟請求壓縮
mime-types: text/html,application/xml,application/json # 設置壓縮的數(shù)據(jù)類型,此處也是默認值
min-request-size: 2048 # 設置觸發(fā)壓縮的??下限,此處也是默認值
response:
enabled: true # 開啟響應壓縮
4、Feign的日志級別配置
Feign是http請求客戶端,類似于咱們的瀏覽器,它在請求和接收響應的時候,可以打印出比較詳細的?些日志信息(響應頭,狀態(tài)碼等等)
如果我們想看到Feign請求時的日志,我們可以進行配置,默認情況下Feign的日志沒有開啟。
開啟Feign日志功能及級別
// Feign的?志級別(Feign請求過程信息) // NONE:默認的,不顯示任何?志----性能最好 // BASIC:僅記錄請求?法、URL、響應狀態(tài)碼以及執(zhí)?時間----?產(chǎn)問題追蹤 // HEADERS:在BASIC級別的基礎上,記錄請求和響應的header // FULL:記錄請求和響應的header、body和元數(shù)據(jù)----適?于開發(fā)及測試環(huán)境定位問題 import feign.Logger; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class FeignLog { @Bean Logger.Level feignLevel() { return Logger.Level.FULL; } }
配置log日志級別為debug
logging:
level:
# Feign?志只會對?志級別為debug的做出響應
com.lagou.edu.controller.service.ResumeServiceFeignClient: debug
到此這篇關于SpringCloud Feign高級配置詳解的文章就介紹到這了,更多相關SpringCloud Feign內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
聊聊Spring MVC JSON數(shù)據(jù)交互的問題
我們在開發(fā)中后端經(jīng)常需要接受來自于前端傳遞的Json字符串數(shù)據(jù),怎么把Json字符串轉換為Java對象呢?下面小編給大家?guī)砹薙pring MVC JSON數(shù)據(jù)交互的問題,感興趣的朋友一起看看吧2021-10-10Java利用happen-before規(guī)則如何實現(xiàn)共享變量的同步操作詳解
這篇文章主要給大家介紹了關于Java利用happen-before規(guī)則實現(xiàn)共享變量的同步操作的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用java具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-06-06基于Java SSM框架實現(xiàn)簡易的評教系統(tǒng)
這篇文章主要介紹了通過Java SSM框架實現(xiàn)一個簡易的評教系統(tǒng)的示例代碼,文中的代碼講解詳細,感興趣的小伙伴可以了解一下2022-02-02舉例講解Java的Hibernate框架中的多對一和一對多映射
這篇文章主要介紹了Java的Hibernate框架中的多對一和一對多映射,Hibernate是Java的SSH三大web開發(fā)框架之一,需要的朋友可以參考下2015-12-12詳解SpringBoot中RestTemplate的幾種實現(xiàn)
這篇文章主要介紹了詳解SpringBoot中RestTemplate的幾種實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-11-11