日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Spring Cloud Feign 自定義配置(重試、攔截與錯誤碼處理) 代碼實踐

瀏覽:180日期:2023-08-19 14:55:19

基于 spring-boot-starter-parent 2.1.9.RELEASE, spring-cloud-openfeign 2.1.3.RELEASE

引子

Feign 是一個聲明式、模板化的HTTP客戶端,簡化了系統發起Http請求。創建它時,只需要創建一個接口,然后加上FeignClient注解,使用它時,就像調用本地方法一樣,作為開發者的我們完全感知不到這是在調用遠程的方法,也感知不到背后發起了HTTP請求:

/** * @author axin * @suammry xx 客戶端 */@FeignClient(value = 'xxClient',url = '${xx.host:www.axin.com}')public interface DemoClient { @PostMapping(value = '/xxx/url', headers = 'Content-Type=application/json'}) yourResponse requestHTTP(@RequestBody JSONObject param);}

上述的代碼就是一個定義一個Feign HTTP 客戶端,在其他類中只需要 @Autowired DemoClient,就可以像調用本地方法一樣發起HTTP請求。

介紹就到這,接下來進入主題,因為 FeignClient 將發起HTTP請求與解析返回報文都做了包裝,如果你的業務場景需要定制一些調用機制,比如:

我想在發起請求響應超時失敗時自動重試 —— 自定義重試機制 我想單獨對某些異常的HTTP狀態碼特殊處理 —— 自定義ErrorDecoder 服務端接口需要驗證簽名,所以我方在發起請求時要生成簽名然后傳過去 —— 定義 Fegin 攔截器

基于此,本文就以上述3個需求場景為例來介紹如何自定義 FeignClient 的配置

FeignClient的默認配置類

Feign Client 默認的配置類為 FeignClientsConfiguration, 這個類在 spring-cloud-netflix-core 的 jar 包下。

默認注入了很多 Feign 相關的配置Bean,包括FeignRetryer、 FeignLoggerFactory 和 FormattingConversionService 等。另外,Decoder、Encoder和 Contract 這3個類在沒有Bean被注入的情況下,會自動注入默認配置的 Bean,即ResponseEntity Decoder、SpringEncoder 和 SpringMvcContract。

如果你不知道如何自己定義配置時,不放點進去看看人家默認配置是如何實現的。這里就不曬源碼了。

FeignClient 注解參數

每個注解參數都做了注釋,詳情請見下方源碼:

@Target(ElementType.TYPE)@Retention(RetentionPolicy.RUNTIME)@Documentedpublic @interface FeignClient {/** * 指定FeignClient的名稱,如果項目使用了Ribbon,name屬性會作為微服務的名稱,用于服務發現 */@AliasFor('name')String value() default '';@DeprecatedString serviceId() default '';@AliasFor('value')String name() default '';/** * Sets the <code>@Qualifier</code> value for the feign client. * 這個bean在應用上下文中的名字為接口的全限定名,你也可以使用 @FeignClient 注解中的 qualifier 屬性給bean指定一個別名 */String qualifier() default '';/** * url地址 */String url() default '';/** * 當發生404錯誤,如果該字段為true,會調用decoder進行解碼,否則拋出FeignException */boolean decode404() default false;/** * 指定FeignClient 的配置類,優先級最高,默認的配置類為 FeignClientsConfiguration類 */Class<?>[] configuration() default {};/** * 配置熔斷器的處理類 */Class<?> fallback() default void.class;/** * 工廠類,用于生產fallback類示例,通過這個屬性我們可以實現每個接口通用的容錯邏輯,減少重復代碼 */Class<?> fallbackFactory() default void.class;/** * 定義統一的路徑前綴 */String path() default '';/** * Whether to mark the feign proxy as a primary bean. Defaults to true. */boolean primary() default true;}

自定義Feign配置類

在 Spring Cloud 中,你可以通過 @FeignClient 注解聲明額外的配置(比 FeignClientsConfiguration 級別高)去控制feign客戶端,以一開始的feign接口為例:

/** * @author axin * @suammry xx 客戶端 */@FeignClient(value = 'xxClient',url = '${xx.host:www.axin.com}',configuration = MyConfiguration.class)public interface DemoClient { @PostMapping(value = '/xxx/url', headers = 'Content-Type=application/json'}) yourResponse requestHTTP(@RequestBody JSONObject param);}

在上面這個示例中,feign客戶端在MyConfiguration中的配置將會覆蓋FeignClientsConfiguration中的配置。

要注意的是: MyConfiguration不需要使用@Configuration注解。如果加上了,它將全局生效。

Retryer-重試機制的自定義

/** * @author axin * @summary fegin 客戶端的自定義配置 */public class MyConfiguration { /** * 自定義重試機制 * @return */ @Bean public Retryer feignRetryer() { //fegin提供的默認實現,最大請求次數為5,初始間隔時間為100ms,下次間隔時間1.5倍遞增,重試間最大間隔時間為1s, return new Retryer.Default(); }}

ErrorDecoder-錯誤解碼器的自定義

當feign調用返回HTTP報文時,會觸發這個方法,方法內可以獲得HTTP狀態碼,可以用來定制一些處理邏輯等等。

/** * @author axin * @summary fegin 客戶端的自定義配置 */@Slf4jpublic class MyConfiguration { /** * 自定義重試機制 * @return */ @Bean public Retryer feignRetryer() { //最大請求次數為5,初始間隔時間為100ms,下次間隔時間1.5倍遞增,重試間最大間隔時間為1s, return new Retryer.Default(); } @Bean public ErrorDecoder feignError() { return (key, response) -> { if (response.status() == 400) {log.error('請求xxx服務400參數錯誤,返回:{}', response.body()); } if (response.status() == 409) {log.error('請求xxx服務409異常,返回:{}', response.body()); } if (response.status() == 404) {log.error('請求xxx服務404異常,返回:{}', response.body()); } // 其他異常交給Default去解碼處理 // 這里使用單例即可,Default不用每次都去new return new ErrorDecoder.Default().decode(key, response); }; }}

采用了lambda的寫法,response變量是Response類型,通過status()方法可以拿到返回的HTTP狀態碼,body()可以獲得到響應報文。

Feign攔截器實踐

攔截器在請求發出之前執行,在攔截器代碼里可以修改請求參數,header等等,如果你有簽名生成的需求,可以放在攔截器中來實現

/** * @author axin * @summary fegin 客戶端的自定義配置 */@Slf4jpublic class MyConfiguration { /** * 自定義重試機制 * @return */ @Bean public Retryer feignRetryer() { //最大請求次數為5,初始間隔時間為100ms,下次間隔時間1.5倍遞增,重試間最大間隔時間為1s, return new Retryer.Default(); } @Bean public ErrorDecoder feignError() { return (key, response) -> { if (response.status() == 400) {log.error('請求xxx服務400參數錯誤,返回:{}', response.body()); } if (response.status() == 409) {log.error('請求xxx服務409異常,返回:{}', response.body()); } if (response.status() == 404) {log.error('請求xxx服務404異常,返回:{}', response.body()); } // 其他異常交給Default去解碼處理 // 這里使用單例即可,Default不用每次都去new return new ErrorDecoder.Default().decode(key, response); }; } /** * fegin 攔截器 * @return */ @Bean public RequestInterceptor cameraSign() { return template -> { // 如果是get請求 if (template.method().equals(Request.HttpMethod.GET.name())) {//獲取到get請求的參數Map<String, Collection<String>> queries = template.queries(); } //如果是Post請求 if (template.method().equals(Request.HttpMethod.POST.name())) {//獲得請求bodyString body = template.requestBody().asString();JSONPObject request = JSON.parseObject(body, JSONPObject.class); } //Do what you want... 例如生成接口簽名 String sign = '根據請求參數生成的簽名'; //放入url?之后 template.query('sign', sign); //放入請求body中 String newBody = '原有body' + sign; template.body(Request.Body.encoded(newBody.getBytes(StandardCharsets.UTF_8), StandardCharsets.UTF_8)); }; }}

可以看到代碼中給了如何獲取請求參數和修改請求參數的示例。

總結

小結一下,對于開頭提出的場景:

我想在發起請求響應超時失敗時自動重試 —— 自定義重試機制 我想單獨對某些異常的HTTP狀態碼特殊處理 —— 自定義ErrorDecoder 服務端接口需要驗證簽名,所以我方在發起請求時要生成簽名然后傳過去 —— 定義 Fegin 攔截器

給出了自定義 feign 配置的方式實現的樣例代碼,希望對你有用,如果有更好的方式簡化HTTP請求,歡迎留言分享~

參考鏈接

重新定義Spring Cloud實戰

Spring Cloud Netflix官方文檔

總結

到此這篇關于Spring Cloud Feign 自定義配置(重試、攔截與錯誤碼處理) 實踐的文章就介紹到這了,更多相關Spring Cloud Feign 自定義配置內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
婷婷综合国产| 婷婷成人av| 久久免费视频66| 国产探花一区| 国产日韩欧美三级| 国产精品2区| 另类综合日韩欧美亚洲| 老司机精品在线| 精品视频一区二区三区四区五区 | 欧美一级二区| 久久精品97| 国产福利亚洲| 亚洲国产成人二区| 日韩成人精品一区| 国产不卡人人| 久久精品91| 在线视频亚洲| 亚洲精品免费观看| 国产精品视频一区二区三区| 久久99久久人婷婷精品综合| 色在线视频观看| 狠狠久久婷婷| 日韩一区二区三区免费视频| 国产九九精品| 日韩伦理福利| 国产亚洲一区在线| 91亚洲精品在看在线观看高清| 国产日产高清欧美一区二区三区 | 亚洲精品系列| 国产毛片一区二区三区| 精品黄色一级片| 久久久夜精品| 亚州精品视频| а√天堂8资源中文在线| jiujiure精品视频播放| 久久性天堂网| 国产伦精品一区二区三区视频 | 麻豆一区二区三区| 91精品精品| 亚洲欧洲国产精品一区| 欧美激情综合| 狠狠色综合网| 欧美国产日韩电影| 久久中文字幕av| 日韩av中文字幕一区二区三区| 福利片在线一区二区| 黄色亚洲在线| 国产精品久久免费视频| 亚洲v在线看| 日本不卡一区二区| 欧美xxxx中国| 综合视频一区| av资源新版天堂在线| 免费在线观看成人| 国产aa精品| 蜜臀av国产精品久久久久| 久久精品国产成人一区二区三区| 国产主播一区| 国产精成人品2018| 欧美午夜精彩| 国产欧美高清| 日韩亚洲精品在线| 九九九精品视频| 久久国产精品毛片| 国产精品麻豆久久| 日韩精品视频中文字幕| 色在线视频观看| 日本午夜精品久久久久| 久久国产中文字幕| 国产乱码精品| 天堂av在线一区| 亚洲综合电影| 国产九九精品| 美女精品一区| 欧美亚洲精品在线| 老司机精品视频网| 日韩中文字幕无砖| 精品一区三区| 国产在线观看91一区二区三区| 蜜臀va亚洲va欧美va天堂 | 福利一区在线| 欧美一区久久| 丝袜亚洲另类欧美| 久久久9色精品国产一区二区三区| 国产麻豆精品久久| 在线一区二区三区视频| 久久国产电影| 国产一区二区三区精品在线观看| 人人爱人人干婷婷丁香亚洲| 日韩视频二区| 亚洲91久久| 超级白嫩亚洲国产第一| 国产日韩欧美在线播放不卡| 国产亚洲毛片| 欧美日韩精品一区二区视频| 精品视频国内| 久久99精品久久久久久园产越南| 日韩影片在线观看| 免费在线观看精品| 国产女优一区| 免费观看不卡av| 中文字幕人成乱码在线观看| 国产精品99精品一区二区三区∴ | 影院欧美亚洲| 国产精品99免费看| 91精品推荐| 日韩深夜视频| 国产精品777777在线播放| 日韩精品午夜视频| 日韩综合一区二区三区| 亚洲欧美激情诱惑| 黄色免费成人| 午夜久久福利| 欧美a级片一区| 99tv成人| 99精品网站| 蜜臀久久99精品久久一区二区| 午夜av成人| 青青青免费在线视频| 久久久久亚洲精品中文字幕| 国产精品久久久久久久久免费高清 | 久久亚洲国产精品尤物| 国产精品a久久久久| 国产精品欧美日韩一区| 久久国产人妖系列| 欧美日韩亚洲一区在线观看| 综合国产视频| 亚洲人成高清| 日本亚洲三级在线| 日本精品久久| 日韩va亚洲va欧美va久久| 日韩国产精品久久久| 欧美一级二级三级视频| 国产毛片精品| 卡一精品卡二卡三网站乱码| 国产九一精品| 国产一区二区三区四区五区| bbw在线视频| 亚洲调教视频在线观看| 国产精品女主播一区二区三区| 亚洲免费影院| 日韩欧美另类中文字幕| 久久国产免费看| 久久精品系列| 色爱综合av| 国产精品毛片| 日韩成人精品一区二区三区| 国产乱人伦精品一区| 国产成人在线中文字幕| 日韩免费av| re久久精品视频| 蜜芽一区二区三区| 国产精品2区| av在线日韩| 欧美专区18| 国产精品1luya在线播放| 美女av在线免费看| 亚洲一区免费| 国产精品第一| 久久久久99| 亚洲一区二区日韩| 麻豆国产一区| 国产真实久久| 日本中文字幕不卡| 精品国产一区二区三区2021| 精品捆绑调教一区二区三区| 一本一本久久| 国产精品一区二区99| 欧洲一区二区三区精品| 国产亚洲欧洲| 精品一区二区三区四区五区| 久久久噜噜噜| 69堂精品视频在线播放| 日韩一区二区三区在线免费观看| 久久亚洲图片| 精品国产中文字幕第一页| 香蕉国产精品| 国产欧美丝祙| 久久精品官网| 日本一区二区三区中文字幕| 精品日本视频| 亚洲一区免费| 久久天堂影院| 蜜桃传媒麻豆第一区在线观看| 精品国产一区二区三区噜噜噜| 欧美二区视频| 欧美中文一区| 五月婷婷亚洲| 久久精品一区二区国产| 9国产精品视频| 精品99在线| 亚洲无线观看| 色爱av综合网| 国产一卡不卡| 伊人久久成人| 国产一区二区三区四区二区| 美女尤物久久精品| 久久久国产亚洲精品| 美女精品视频在线| 一区二区电影在线观看|