Spring Cloud中怎么配置Feign組成,相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。
在革吉等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專(zhuān)注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、外貿(mào)營(yíng)銷(xiāo)網(wǎng)站建設(shè) 網(wǎng)站設(shè)計(jì)制作定制設(shè)計(jì),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計(jì),成都全網(wǎng)營(yíng)銷(xiāo)推廣,外貿(mào)營(yíng)銷(xiāo)網(wǎng)站建設(shè),革吉網(wǎng)站建設(shè)費(fèi)用合理。
Feign的組成
接口 | 作用 | 默認(rèn)值 |
---|---|---|
Feign.Builder | Feign的入口 | Feign.Builder |
Client | Feign底層用什么去請(qǐng)求 | 和Ribbon配合時(shí):LoadBalancerFeignClient 不和Ribbon配合時(shí):Fgien.Client.Default |
Contract | 契約,注解支持 | SpringMVCContract |
Encoder | 解碼器,用于將獨(dú)享轉(zhuǎn)換成HTTP請(qǐng)求消息體 | SpringEncoder |
Decoder | 編碼器,將相應(yīng)消息體轉(zhuǎn)成對(duì)象 | ResponseEntityDecoder |
Logger | 日志管理器 | Slf4jLogger |
RequestInterceptor | 用于為每個(gè)請(qǐng)求添加通用邏輯(攔截器,例子:比如想給每個(gè)請(qǐng)求都帶上heared) | 無(wú) |
Feign的日記級(jí)別
日志級(jí)別 | 打印內(nèi)容 |
---|---|
NONE(默認(rèn)) | 不記錄任何日志 |
BASIC | 僅記錄請(qǐng)求方法,URL,響應(yīng)狀態(tài)代碼以及執(zhí)行時(shí)間(適合生產(chǎn)環(huán)境) |
HEADERS | 記錄BASIC級(jí)別的基礎(chǔ)上,記錄請(qǐng)求和響應(yīng)的header |
FULL | 記錄請(qǐng)求和弦ineader,body和元數(shù)據(jù) |
首先如何整合Feign
遵循SpringBoot的三板斧第一步:加依賴(lài)
org.springframework.cloud spring-cloud-starter-openfeign
第二步:寫(xiě)注解
@EnableFeignClients //在啟動(dòng)類(lèi)上加
第三步:寫(xiě)配置
如何給Feign添加日志級(jí)別
細(xì)粒度
方式一:代碼實(shí)現(xiàn)第一步:添加Feign配置類(lèi),可以添加在主類(lèi)下,但是不用添加@Configuration。如果添加了@Configuration而且又放在了主類(lèi)之下,那么就會(huì)所有Feign客戶端實(shí)例共享,同Ribbon配置類(lèi)一樣父子上下文加載沖突;如果一定添加@Configuration,就放在主類(lèi)加載之外的包。建議還是不用加@Configuration。
public class FeignConfig { @Bean public Logger.Level Logger() { return Logger.Level.FULL; } }
第二步:給@FeignClient添加配置類(lèi)
//@FeignClient configuration = GoodsFeignConfig.class 細(xì)粒度配置,指定配置類(lèi) @FeignClient(name = "goods", configuration = FeignConfig.class)
第四步:寫(xiě)配置
logging: level: com.xxx.xxx.FeignAPI: DEBUG #需要將FeignClient接口全路徑寫(xiě)上# 開(kāi)啟日志 格式為logging.level. Feign客戶端路徑
方式二:配置屬性實(shí)現(xiàn)
feign: client: config: #想要調(diào)用的微服務(wù)名稱(chēng) server-1: loggerLevel: FULL
全局配置
方式一:代碼實(shí)現(xiàn)添加了@Configuration放在了主類(lèi)之下,那么就會(huì)所有Feign客戶端實(shí)例共享,同Ribbon配置類(lèi)一樣父子上下文加載沖突;讓父子上下文ComponentScan重疊(強(qiáng)烈不建議)唯一正確方式
//在啟動(dòng)類(lèi)上為@EnableFeignClients注解添加defaultConfiguration配置 @EnableFeignClients(defaultConfiguration = FeignConfig.class)
方式二:配置屬性實(shí)現(xiàn)
feign: client: config: #將調(diào)用的微服務(wù)名稱(chēng)改成default就配置成全局的了 default: loggerLevel: FULL
Feign支持的配置項(xiàng)
代碼方式
配置項(xiàng) | 作用 |
---|---|
Logger.Level | 指定日志級(jí)別 |
Retryer | 指定重試策略 |
ErrorDecoder | 指定錯(cuò)誤解碼器 |
Request.Options | 超時(shí)時(shí)間 |
Collection | 攔截器 |
SetterFactory | 用于設(shè)置Hystrix的配置屬性,F(xiàn)gien整合Hystrix才會(huì)用 |
配置屬性
feign: client: config: feignName: connectTimeout: 5000 # 相當(dāng)于Request.Optionsn 連接超時(shí)時(shí)間 readTimeout: 5000 # 相當(dāng)于Request.Options 讀取超時(shí)時(shí)間 loggerLevel: full # 配置Feign的日志級(jí)別,相當(dāng)于代碼配置方式中的Logger errorDecoder: com.example.SimpleErrorDecoder # Feign的錯(cuò)誤解碼器,相當(dāng)于代碼配置方式中的ErrorDecoder retryer: com.example.SimpleRetryer # 配置重試,相當(dāng)于代碼配置方式中的Retryer requestInterceptors: # 配置攔截器,相當(dāng)于代碼配置方式中的RequestInterceptor - com.example.FooRequestInterceptor - com.example.BarRequestInterceptor # 是否對(duì)404錯(cuò)誤解碼 decode404: false encode: com.example.SimpleEncoder decoder: com.example.SimpleDecoder contract: com.example.SimpleContract
Feign還支持對(duì)請(qǐng)求和響應(yīng)進(jìn)行GZIP壓縮,以提高通信效率,配置方式如下:
# 配置請(qǐng)求GZIP壓縮 feign.compression.request.enabled=true # 配置響應(yīng)GZIP壓縮 feign.compression.response.enabled=true # 配置壓縮支持的MIME TYPE feign.compression.request.mime-types=text/xml,application/xml,application/json # 配置壓縮數(shù)據(jù)大小的下限 feign.compression.request.min-request-size=2048
Ribbon配置 VS Feign配置
粒度 | Ribbon | Feign |
---|---|---|
代碼局部 | @RibbonClient(configuration=RibbonConfig.class),RibbonConfig類(lèi)必須加@Configuration,且必須放在父上下文無(wú)法掃到的包下 | @FeignClient(configuration=FeignConfig.class),F(xiàn)eignConfig類(lèi)的@Configuration可以不加(可選),如果有,必須放在父上下文無(wú)法掃到的包下 |
代碼全局 | @RibbonClients(defaultConfigurtion=RibbonConfig.class) | @EnableFeignClients(defaultConfiguration = FeignConfig.class) ... |
配置屬性局部 | .ribbon.NFLoadBalancerClassName ... | feign.client.config..loggerLevel ... |
配置屬性全局 | 無(wú) | feign.client.config.default.loggerLevel |
Feign 代碼方式 VS 配置屬性方式
配置方式 | 有點(diǎn) | 缺點(diǎn) |
---|---|---|
代碼配置 | 基于代碼,更加靈活 | 如果Feign的配置類(lèi)加了@Configuration注解,需注意父子上下文,線上修改需要重打包,發(fā)布 |
屬性配置 | 易上手 配置更加直觀 線上修改無(wú)需重新打包,發(fā)布 優(yōu)先級(jí)更高 | 極端場(chǎng)景下沒(méi)有代碼配置更加靈活 |
看完上述內(nèi)容,你們掌握Spring Cloud中怎么配置Feign組成的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!