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

SpringCloud Feign高級配置詳解

 更新時間:2022年09月01日 10:21:13   作者:悠然予夏  
這篇文章主要介紹了SpringCloud Feign高級配置,feign是netflix提供的服務間基于http的rpc調用框架,在spring cloud得到廣泛應用

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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論