九九国产视频,又色又爽又黄的视频大片,中文字幕亚洲综合久久菠萝蜜,久久精品成人亚洲另类欧美,99免费在线视频

首頁>資訊 > 綜合資訊 > 正文

Feign如何設置超時時間,不同情況下還真不一樣

來源:三友的java日記    2023-08-15 10:23:20

大家好,我是三友~~

今天來聊一聊前段時間看到的一個面試題,也是在實際項目中需要考慮的一個問題,F(xiàn)eign的超時時間如何設置?

Feign的超時時間設置方式并不固定,它取決于Feign在項目中是如何使用的,不同的使用方式,超時時間設置方式也不大相同,甚至還可能有坑。


(資料圖片)

前置知識

由于文章會涉及到Feign的底層知識,如果不懂點Feign的基本概念的話,后面就看不下去了

所以為了方便不了解Feign的小伙伴也能夠讀得懂文章,這里我就簡單地說說Feign的原理,點到為止,雖然不深入,但足夠應付這篇文章了

Feign的作用

在項目中,我們經常需要調用第三方提供的Http接口,此時我們就可以使用一些Http框架來實現(xiàn),比如HttpClient

public class HttpClientDemo {    public static void main(String[] args) throws Exception {        //創(chuàng)建一個HttpClient        HttpClient httpClient = HttpClientBuilder.create().build();        //構建一個get請求        HttpGet httpGet = new HttpGet("http://192.168.100.1:8080/order/1");        //發(fā)送請求,獲取響應        HttpResponse httpResponse = httpClient.execute(httpGet);        HttpEntity httpEntity = httpResponse.getEntity();        //讀出響應值        String response = EntityUtils.toString(httpEntity);        System.out.println("Response: " + response);    }}

如果項目中只有一兩個這種第三方接口這樣寫還行,但是一旦這種三方接口過多的話,每次都得這樣組裝參數(shù),發(fā)送請求,寫一堆同樣的代碼,就顯然很麻煩了。

所以為了簡化發(fā)送Http請求的開發(fā),減少重復代碼,F(xiàn)eign就出現(xiàn)了。

Feign是一個聲明式的Http框架

當你需要調用Http接口時,你需要聲明一個接口,加一些注解就可以了

而像組裝參數(shù)、發(fā)送Http請求等重復性的工作都交給Feign來完成。

Feign的原理

雖然有了接口,但是僅僅有接口是不夠的,因為接口又不能創(chuàng)建對象,我們得需要對象。

Feign為了方便我們?yōu)榻涌趧?chuàng)建對象,提供的Feign.Builder這個內部類

圖片

這個類的作用就是解析接口的上的注解,為接口生成一個動態(tài)代理對象,后面通過這個代理對象就可以發(fā)送請求了。

這個內部類有很多屬性,這些屬性都是Feign的核心組件。

在這些核心的組件中有一個叫Client的,上圖中我圈出來了。

圖片

這個Client類劃個重點,非常非常重要,本文討論的東西跟他有密切關系。

它只有一個方法Response execute(Request request, Options options)

方法的第一個參數(shù)Request就是封裝了http請求的url、請求方法,請求頭、請求體之類的參數(shù)

圖片

第二個參數(shù)Options就是本文的主題,封裝了超時時間。

圖片

返回值Response就是封裝了一些響應碼status、響應頭之類的

圖片

所以通過方法的參數(shù)和返回值也可以猜出來,這個Client作用是用來組裝Http請求參數(shù),發(fā)送Http請求的

并且http請求超時時間是根據傳給Client的Options參數(shù)來決定的

圖片

如果想更深一步了解Feign原理,可在公眾號菜單欄springcloud分類中查看

Feign單獨使用時超時時間設置

Feign本身就是一個http客戶端,可獨立使用,F(xiàn)eign提供了兩種超時時間設置方式

1、通過Feign.Builder設置

前面提到,F(xiàn)eign.Builder的作用是為接口的動態(tài)代理對象的

Feign.Builder里面有很多屬性,其中就有關于超時時間的屬性Options

圖片

如果你不設置,那么超時時間就是默認的

圖片

默認的就是連接超時10s,讀超時60s

所以可以通過設置Feign.Builder中的options來設置超時時間

來個demo

環(huán)境準備,就是一個簡單的SpringBoot項目,引入一個Feign的依賴

            org.springframework.cloud        spring-cloud-starter-openfeign        2.2.5.RELEASE    

聲明接口 + 注解

public interface UserApi {    @RequestLine("GET /user/{userId}")    User queryUser(@Param("userId") Integer userId);}

這里演示的是Feign原生的使用方式,脫離于SpringCloud環(huán)境,所以Spring的那些@GetMappring就不支持了,改用Feign本身提供的注解

測試代碼

public class FeignDemo {    public static void main(String[] args) {        UserApi client = Feign.builder()                //設置連接和讀超時間都是5s                .options(new Request.Options(5, TimeUnit.SECONDS, 5, TimeUnit.SECONDS, true))                .target(UserApi.class, "http://localhost:8088");        User user = client.queryUser(123);    }}

這里面的請求路徑都是不存在的,因為我們只關心傳給Client的Options參數(shù)值

Client在我們不設置的時候,就用默認的實現(xiàn)Client.Default

圖片

斷點打到execute方法的實現(xiàn),運行,走起

圖片

結果就是我們設置的5s

2、在接口方法參數(shù)設置

除了在通過Feign.Builder時設置之外,F(xiàn)eign還支持在接口的方法參數(shù)上設置

此時你只需要在接口的方法上加一個Options類型的參數(shù)

@RequestLine("GET /user/{userId}")User queryUser(@Param("userId") Integer userId, Request.Options options);

這樣在傳參數(shù)時就可以設置超時時間了

User user = client.queryUser(123, new Request.Options(3, TimeUnit.SECONDS, 3, TimeUnit.SECONDS, true));

同樣地,debug就可以看見我們設置的3s了

圖片

這兩種設置超時時間的主要區(qū)別就是方法參數(shù)設置超時時間的優(yōu)先級高于Feign.Builder設置的超時時間

用一張圖來總結一下上面的關系

圖片

所以,如果你單獨使用Feign的時候,你就可以通過如上的兩種方式來設置超時時間。

SpringCloud下Feign單獨使用超時時間設置

在SpringCloud環(huán)境下,只是對Feign進行了一層包裝,所以即使沒有Ribbon和注冊中心,F(xiàn)eign也是可以單獨使用的,但是用法有點變化

注解都換成SpringMVC的注解接口上需要加@FeignClient注解用@EnableFeignClients掃描這些接口

不過,默認情況下Feign還是需要結合Ribbon來使用的

如果你只想單獨使用Feign,那么就設置一下@FeignClient注解的url屬性,指定請求的地址和端口就可以了

圖片

所以,既然只是包裝,前面提到的兩種方式設置超時時間當然可以繼續(xù)使用:

通過Feign.Builder通過接口的方法參數(shù)

方法參數(shù)設置形式跟前面提到的一模一樣,但是通過Feign.Builder來設置卻不太一樣

由于SpringCloud會自己創(chuàng)建Feign.Builder,不需要我們創(chuàng)建,所以在設置Options時,Spring提供了兩種快捷方式來設置

不過最終還是設置到Feign.Builder中

1、聲明一個Options Bean

Spring在構建Feign.Builder的時,會從容器中查找Options這個Bean,然后設置到Feign.Builder中

@Configurationpublic class FeignConfiguration {    @Bean    public Request.Options options() {        return new Request.Options(8, TimeUnit.SECONDS, 8, TimeUnit.SECONDS, true);    }}

此時debug就可以看到設置到Feign.Builder的代碼

圖片

這段代碼在FeignClientFactoryBean中的configureUsingConfiguration方法中

2、配置文件中設置

除了聲明Bean之外,Spring還提供了通過配置文件的方式配置,如下:

feign:  client:    config:      default:        connectTimeout: 10000        readTimeout: 10000

同樣地,debug就可以看見

圖片

這段代碼在FeignClientFactoryBean中的configureUsingConfiguration方法中

聲明Bean和配置文件都可以設置,那么同時設置哪種優(yōu)先級高呢?

如無特殊配置,遵守SpringBoot本身的配置規(guī)定

約定 > 配置 > 編碼

所以基于這個規(guī)定,配置文件的配置優(yōu)先級大于手動聲明Bean的優(yōu)先級。

到這,我們又學到了兩種Spring為了方便我們設置Feign.Builder提供的配置方式:

聲明Options Bean配置文件

把他們倆加到前面畫的圖中

圖片

所以,如果你使用了SpringCloud提供的方式來使用Feign,那么就可以通過聲明OptionsBean和配置文件的方式更加方便地來設置超時時間

最終其實還是通過Feign.Builder來設置的

SpringCloud下通過Ribbon來設置

當Feign配合Ribbon使用時,除了上面兩種方式之外,還可以通過Ribbon來設置超時時間。

但是這里我不知道你會不會好奇

Ribbon不是負載均衡組件,怎么可以設置超時時間?

其實這跟Ribbon的定位有關,除了負載均衡組件之外,Ribbon也干發(fā)送Http請求的事,也就是不配合Feign,他照樣可以發(fā)送http請求。

來個簡單demo

圖片

解釋一下上面的代碼意思

第一步,設置user服務的兩個服務實例地址第二步,獲取user服務對應的RestClient,這RestClient就可以用來發(fā)送http請求第三步,構建一個http請求第四步,就是發(fā)送http請求,以負載均衡的方式

這樣,此時就會從兩個服務實例中根據負載均衡選取一個服務地址發(fā)送http請求,

Ribbon既然可以發(fā)送Http請求,那么自然而然就可以設置超時時間

Feign在整合Ribbon的時候,為了統(tǒng)一配置,就默認將自己的超時時間交由Ribbon管理

所以,在默認情況下,F(xiàn)eign的超時時間可以由Ribbon配置

而Ribbon默認連接和讀超時時間只有1s,所以在默認情況下,F(xiàn)eign的超時時間只有1s。

圖片

IClientConfig是Ribbon的配置類,Ribbon所有的配置都可以從IClientConfig中獲取。

所以,在默認情況下,很容易就發(fā)生超時,不過我們可以通過配置文件修改即可

ribbon:  ConnectTimeout: 5000  ReadTimeout: 5000

你知道你發(fā)現(xiàn)沒,上面說通過Ribbon設置Feign的超時時間,一直提到前面一直提到這個詞

默認

什么情況下叫默認呢?

所謂的默認,就是當你不主動設置Feign的超時時間的時候,就是默認。

換句話說,一旦你通過上面說的那些配置方式設置Feign的超時時間,就不是默認了

此時通過Ribbon設置的超時時間就不會生效了

Feign是如何在默認情況下將超時時間交給Ribbon管理的?

要想回答這個問題,就得先搬出前面反復提到的Client接口了。

在SpringCloud的環(huán)境下,有一個Client的實現(xiàn),叫LoadBalancerFeignClient

圖片

通過名字就可以看出,帶有負載均衡的Client實現(xiàn),負載均衡的實現(xiàn)肯定是交給Ribbon來實現(xiàn)的

所以當Feign配合Ribbon時用的就是這個Client實現(xiàn)

既然實現(xiàn)了Client接口,那就看看execute方法的實現(xiàn)邏輯

圖片

圖中getClientConfig方法就是判斷使用Feign或者Ribbon配置的核心邏輯

核心的判斷邏輯就是這一行

options == DEFAULT_OPTIONS

DEFAULT_OPTIONS就是一個超時時間的常量

圖片

當上述判斷條件成立時,就會通過this.clientFactory.getClientConfig(clientName)獲取到Ribbon配置

由于這是Ribbon的邏輯,這里就不深扒了,知道是這個意思就行

當條件不成立時,用Options構建一個FeignOptionsClientConfig

圖片

FeignOptionsClientConfig就是簡單地將Options配置讀出來,設置到父類DefaultClientConfigImpl超時時間配置上

DefaultClientConfigImpl就算你不知道是什么也無所謂,你能看出的一件事就是,超時時間用的是傳遞給Client的Options參數(shù)

所以,綜上,我們的問題就變得非常easy了,那就是什么時候

options == DEFAULT_OPTIONS

只有當這個條件成立時,才使用Ribbon的配置。

這里我們先來捋一捋前面提到的東西

前面我們反復提到,Client的Options最終只來自于兩種配置

Feign.Builder方法參數(shù)

所以DEFAULT_OPTIONS這個Options一定是通過上面兩種方法中的其中一種設置的

而方法參數(shù)是不可能設置的成DEFAULT_OPTIONS

因為這是我們控制的,只要我們參數(shù)不傳DEFAULT_OPTIONS,那么永遠都不可能是DEFAULT_OPTIONS。

此時只剩下一種情況,那就是Spring在構建在Feign.Builder的時候,設置成DEFAULT_OPTIONS。

通過查找DEFAULT_OPTIONS的使用,我們可以追蹤到這么一段代碼

圖片

這不就是前面提到的通過聲明Bean的方式來設置超時時間

不同的是它加了@ConditionalOnMissingBean,這個注解就是說,一旦我們自己沒有聲明Options,就用他這個Options

到這終于真像大白了。

我們不設置超時時間,Spring就會給Feign.Builder加一個DEFAULT_OPTIONS這個Options

在執(zhí)行的時候,發(fā)現(xiàn)是DEFAULT_OPTIONS,說明我們沒有主動設置過超是時間,就會使用Ribbon的超時時間。

為了方便理清上面的邏輯,這里整一張圖

圖片

雖然Feign可以使用Ribbon的超時時間,但是Ribbon的配置的優(yōu)先級是最最低的

方法參數(shù) > Feign配置文件 > 聲明Options > Ribbon配置

Feign or Ribbon配置用哪個好?

其實我個人更傾向于使用Ribbon的配置方式。

因為Ribbon除了可以設置超時時間之外,還可以配置重試機制、負載均衡等其它的配置

為了簡化和統(tǒng)一管理配置,使用Ribbon來配置超時時間。

可能你會有疑問,F(xiàn)eign也支持重試機制,為什么不選擇Feign?

這是因為Feign重試機制沒有Ribbon的好

Ribbon重試的時候會換一個服務實例來重試,因為原來出錯的可能不可用

而Feign并不會換一個服務實例重試,他并不知道上一次使用的是哪個服務實例,這就導致可能會出現(xiàn)在一個不可用的服務實例上多次重試的情況。

引入Hystrix時超時時間設置

如果你之前的確沒有研究過關于Feign超時時間的配置關系,那么此時你應該有所收獲了。

但是這就結束了么?

不,事情沒那么簡單。

如果你的項目中使用了Hystrix,那么就得小心前面說的那些配置了。

由于Hystrix跟Feign畢竟是一家人,所以當引入Hystrix時,F(xiàn)eign就跟之前不一樣了。

Hystrix會去干一件事,那就是給每個Feign的http接口保護起來,畢竟Hystrix就是干保鏢這個事的。

但是這沒保護還好,一保護問題就不自覺地出現(xiàn)了。

Hystrix在保護的時候,一旦發(fā)現(xiàn)被保護的接口執(zhí)行的時間超過Hystrix設置的最大時間,就直接進行降級操作。

怎么降級的,這里咱不關心,咱關心的是這個Hystrix超時的最大值是多少。

因為一旦這個時間小于Feign的超時時間,那么就會出現(xiàn)Http接口正在執(zhí)行,也沒有異常,僅僅是因為執(zhí)行時間長,就被降級了。

而Hystrix的默認的超時時間的最大值就只有1s。

圖片

所以就算你Feign超時時間設置的再大,超過1s就算超時,然后被降級,太坑了。。

所以我們需要修改這個默認的超時時間的最大值,具體的配置項如下

hystrix:  command:    default:      execution:        isolation:          thread:            timeoutInMilliseconds: 30000

并且時間上大致要符合下面這個原則

Hystrix超時時間 >= (連接超時時間 + 讀超時時間) * 重試次數(shù)

重試次數(shù)我們前面也提到了,雖然一般我們不設置,但是為了嚴謹還是得加上,因為一次Http接口的執(zhí)行時間肯定跟重試次數(shù)有關,重試次數(shù)越多,時間就越長。

而連接超時時間 + 讀超時時間設置方式,前面提到很多次,不論是通過Feign本身設置還是通過Ribbon來設置,都是可以的

總結

今天給大家扒了扒在不同使用條件下Feign的超時時間設置,總結起來大致如下:

單獨使用Feign時:通過Feign.Builder和方法參數(shù)SpringCloud環(huán)境下單獨使用Feign:方法參數(shù)、配置文件、聲明OptionsBean跟Ribbon配合使用:通過Ribbon的超時參數(shù)設置跟Hystrix配合使用:修改默認的超時時間,盡量符合 Hystrix超時時間 >= (連接超時時間 + 讀超時時間) * 重試次數(shù)

關鍵詞:

Feign如何設置超時時間,不同情況下還真不一樣

大家好,我是三友~~今天來聊一聊前段時間看到的一個面試題,也是在實際

玉米價格再創(chuàng)年內新高

新華財經北京8月15日電進入8月份,玉米價格持續(xù)上漲,中旬再創(chuàng)年內新高

浙南地區(qū)最大天然氣保供工程——浙能溫州LNG接收站進入試運行階段

浙南地區(qū)最大天然氣保供工程——浙能溫州LNG接收站進入試運行階段近日

蘋果m3主機什么時候出

很多用戶都非常的關注蘋果最新發(fā)布的M3處理器,也有消息稱這個處理器將

碳酸鋰:2023Q2海外鋰資源供給更新

澳大利亞2023年二季度,澳大利亞Greenbush、Pilbara、MtCattlin、Finni

央行8月22日將在香港招標發(fā)行3個月期200億元和1年期150億元人民幣央票

證券時報網訊,央行網站消息,為豐富香港高信用等級人民幣金融產品,完

解開混亂:探索電子競技錦標賽瑞士回合形式的奧秘

LPL結束了所有的比賽,即將進入新一階段的備戰(zhàn)集訓。與此同時,LCK仍在

克蘇恩之眼能換什么 克蘇恩之眼換什么

1、墮落神明咒符墮落神明咒符拾取后綁定頸部+11耐力需要等級60裝備:提

武清區(qū) 36個村轉移安置人員已回遷

天津北方網訊:從武清區(qū)防汛抗旱指揮部獲悉,截至8月14日,武清區(qū)大黃

昆明舉辦食源性疾病防控與救治工作培訓班

昆明信息港訊(昆明日報記者徐婕)近日,由昆明市衛(wèi)生健康委主辦、昆明

浙江東日:8月14日融券賣出100股,融資融券余額1.98億元

8月14日,浙江東日(600113)融資買入37 17萬元,融資償還98 97萬元,

淘寶怎么看自己的評價?(淘寶怎么看自己的評價)

小評來為大家解答以上問題。淘寶怎么看自己的評價?,淘寶怎么看自己的

8月17日沈陽有無人機矩陣表演,這些路段將實行交通管制

“第十屆沈陽法庫國際飛行大會航空主題嘉年華活動(無人機矩陣表演)”

安德利08月14日獲滬股通增持4.33萬股

08月14日,安德利獲滬股通增持4 33萬股,最新持股量為36 92萬股,占公

深圳、廣州和佛山是廣東省GDP總量前三位城市,都位于珠三角地區(qū)

廣東省位于我國南部沿海地區(qū),廣東省地處南嶺以南,南瀕南海,與廣西、

口子窖:8月14日融券賣出金額143.53萬元,占當日流出金額的0.91%

同花順數(shù)據中心顯示,口子窖8月14日獲融資買入883 11萬元,占當日買入

筆記本任務管理器在哪里(筆記本任務管理器)

小評來為大家解答以上問題。筆記本任務管理器在哪里,筆記本任務管理器

沈陽現(xiàn)代化都市圈養(yǎng)老服務一體化合作協(xié)議簽署

記者8月14日獲悉,為加快推進沈陽現(xiàn)代化都市圈養(yǎng)老服務發(fā)展建設,促進

俄羅斯秋明州發(fā)生一起交通事故 已致5死2傷

據俄新社報道,當?shù)貢r間8月15日凌晨,俄羅斯秋明州發(fā)生一起交通事故,

磷是什么(磷是什么元素)

磷是第15號化學元素,符號P。處于元素周期表的第三周期、第ⅤA族。磷存

《不完美受害人》:不完美才顯真實

《不完美受害人》:不完美才顯真實

沈陽本周天氣以多云為主 偶有陣雨

末伏啦!夏天大部分難捱的日子算是過去了,但處暑節(jié)氣還沒到,我們不能

木工開孔器哪家好 木工開孔器生產廠家盤點 木工開孔器最常用的型號

大家知道什么是木工開孔器嗎?木工開孔器是一種在制作木工的時候使用的

紅星美凱龍(01528):潘寧、巢艷萍退任職工代表監(jiān)事

智通財經APP訊,紅星美凱龍(01528)發(fā)布公告,唐榮鎮(zhèn)及王守義于公司2023

69年屬雞今年運勢2021年運勢(69年屬雞的今年的運氣)

來為大家解答以上的問題。69年屬雞今年運勢2021年運勢,69年屬雞的今年

遼寧全力以赴打好打贏防汛防臺風這場硬仗

防汛防臺風是一場大戰(zhàn)、一場大考。全省各地各相關部門牢固樹立“防大汛

征求意見!沈陽或將出臺這些政策措施 助力恢復和擴大消費

今年新能源汽車充電終端保有量達到3萬個;多子女家庭可足額提取公積金

手機突然充電超級慢是不是電池問題(手機突然充電超級慢)

諸多的對于手機突然充電超級慢是不是電池問題,手機突然充電超級慢這個

大陸剛宣布對臺反制,國民黨要員就喊話柯文哲,不許大陸企業(yè)中標

大陸剛宣布對臺反制,國民黨要員就喊話柯文哲,不許大陸企業(yè)中標,大陸,

媒體:A股也可以考慮取消印花稅 基本情況講解

大家好,今日關于【媒體:A股也可以考慮取消印花稅】迅速上了的熱搜榜

綜合資訊

+更多

熱點資訊

+更多
股票當天買入可以當天再賣出嗎?初學者怎么炒股?
股票當天買入可以當天再賣出嗎?1、 當天買入的內資股當天不能賣出,只能在下一個交易日賣出,賣出股票的錢當天不能支取,只能在下一個交易 [詳細]

Copyright @ 2008-2020  www.see-asia.cn   All Right Reserved Powered by 財經情報網 版權所有

財經情報網   聯(lián)系郵箱:562 66 29@qq.com

網站備案:滬ICP備2020036824號-12