国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

全網最詳細的OpenFeign講解,肯定有你不知道的

開發 開發工具
OpenFeign是一個非常有用的工具,它為開發者提供了一種簡單而強大的方式來處理遠程服務調用。通過使用OpenFeign,開發者可以專注于業務邏輯,而無需花費太多精力在復雜的網絡編程細節上。

環境:SpringCloud3.1.5

1. 簡介

Spring Cloud OpenFeign是一種聲明式、模板化的HTTP客戶端,它簡化了遠程調用的編程體驗。在Spring Cloud中使用OpenFeign,開發者可以像調用本地方法一樣使用HTTP請求訪問遠程服務,而無需感知這是在調用遠程方法。

OpenFeign會根據帶有注解的函數信息構建出網絡請求的模板,在發送網絡請求之前,OpenFeign會將函數的參數值設置到這些請求模板中。

在項目啟動階段,OpenFeign框架會自動的掃包流程,從指定的目錄下掃描并加載所有被@FeignClient注解修飾的接口。OpenFeign會針對每一個FeignClient接口生成一個動態代理(JDK)對象,這個動態代理對象會被添加到Spring上下文中,并注入到對應的服務里。

總的來說,Spring Cloud OpenFeign是一種強大的工具,它可以幫助開發者更輕松地實現微服務的遠程調用。

2. OpenFeign配置

2.1 開啟功能

引入依賴

groupId: org.springframework.cloud
artifactId: spring-cloud-starter-openfeign

開啟

@SpringBootApplication
@EnableFeignClients
public class DemoApplication {
  public static void main(String[] args) {
      SpringApplication.run(DemoApplication.class, args);
  }
}

示例

@FeignClient(name = "demoService")
public interface DemoFeign {


  @GetMapping("/info/{id}")
  public Object info(@PathVariable("id") Integer id) ;


}

在 @FeignClient 注解中,name="demoService"是一個客戶端名稱,用于創建 Spring Cloud LoadBalancer 客戶端。你也可以設置 url 屬性(絕對值或主機名)指定一個 URL。

2.2 自定義配置

通過指定@FeignClient  configuration屬性實現自定義配置

@FeignClient(name = "demoService", configuration=DemoConfiguration.class)
public interface DemoFeign {
}

默認情況下Spring Cloud OpenFeign會提供如下的默認Bean:

Decoder feignDecoder:ResponseEntityDecoder  響應內容解碼

Encoder feignEncoder: SpringEncoder

Logger feignLogger: Slf4jLogger

MicrometerCapability micrometerCapability: 如果 feign-micrometer 位于類路徑上,且 MeterRegistry 可用

CachingCapability cachingCapability: 如果使用 @EnableCaching 注解。可通過 feign.cache.enabled 關閉。

Contract feignContract: SpringMvcContract這個的作用就是用來接下@FeignClient注解類中的相應MVC注解

Feign.Builder feignBuilder: FeignCircuitBreaker.Builder構建Feign客戶端的,比如環境中使用了CircuitBreaker,那么就會在調用接口時應用斷路器功能

Client feignClient: 如果 Spring Cloud LoadBalancer 位于類路徑上,則使用 FeignBlockingLoadBalancerClient。如果它們都不在類路徑上,則使用默認的 Feign  Client。默認的Client使用jdk自定的網絡請求 URLConnection。

我們可以在自定義的DemoConfiguration中自定義自己的實現,在DemoConfiguration中你可以自定義如下的Bean:注意:這些bean是 OpenFeign沒有提供的,除了上面介紹的你可以覆蓋自定義實現,你還可以定義下面的bean

Logger.Level
Retryer
ErrorDecoder
Request.Options
Collection<RequestInterceptor>
SetterFactory
QueryMapEncoder
Capability (MicrometerCapability and CachingCapability are provided by default)

接下來會介紹常用的一些自定義配置

  • 動態配置name & url
@FeignClient(name = "${pack.demo.name}", url="${pack.demo.url}")
public interface DemoFeign {
}

配置文件

pack:
  demo:
    name: demoService
    url: http://localhost:8088/demos

  • 超時配置
feign:
  client:
    config:
      default:
        connectTimeout: 5000
        readTimeout: 5000

默認所有的接口請求超時都是5s。

  • 動態設置超時時間

如果啟用了 Feign 客戶端刷新,則每個 Feign 客戶端都會以 feign.Request.Options 作為 refresh-scoped Bean 來創建。這意味著 connectTimeout 和 readTimeout 等屬性可以通過 POST /actuator/refresh 針對任何 Feign 客戶端實例進行刷新。值需要進行如下配置接口

feign:
  client:
    refresh-enabled: true

  • 自定義日志級別

配置文件中設置

logging:
  level:
    '[com.pack.feign.test.DemoFeign]': debug

配置日志基本,兩種方式:1 配置文件;2 定義Bean

feign:
  client:
    config:
      demoService:
        logger-level: full

在自定義配置類中定義為bean

@Bean
public Logger.Level loggerLevel() {
  return Logger.Level.FULL ;
}

  • 自定義重試機制

默認情況下,當請求的接口出現異常不會進行重試,可以通過定義下面bean進行重試

@Bean
public Retryer feignRetryer() {
  Retryer.Default retryer = new Retryer.Default(100, SECONDS.toMillis(1), 2);
  return retryer ;
}

  • 自定義攔截器

默認OpenFeign不提供任何攔截器,如果你需要在請求前進行處理,比如添加請求header,那么你可以自定義攔截器實現

@Bean
public RequestInterceptor headerRequestInterceptor() {
  return template -> {
    template.header("X-API-TOKEN", "666666") ;
  } ;
}

也可以通過配置文件配置

feign:
  client:
    config:
      demoService:
        request-interceptors:
        - com.pack.feign.HeaderRequestInterceptor

  • 手動創建Feign客戶端

在某些情況下,可能需要自定義 Feign 客戶端,你可以使用 Feign Builder API 創建客戶端。下面的示例創建了兩個具有相同接口的 Feign Client,但每個客戶端都配置了單獨的請求攔截器。

public class DemoController {


  private DemoFeign demoFeign ;


  @Autowired
  public DemoController(Client client, Encoder encoder, Decoder decoder) {
    this.fooClient = Feign.builder().client(client)
        .encoder(encoder)
        .decoder(decoder)
        .requestInterceptor(new HeaderRequestInterceptor("X-API-TOKEN", "666666"))
        .target(FooClient.class, "http://localhost:8088/demos");
  }
}

  • 服務降級

當你的類路徑下有了Spring Cloud CircuitBreaker后服務降級fallback才會生效。

@FeignClient(
    url = "http://localhost:8088/demos", 
    name = "demoService", 
    configuration = DemoFeignConfiguration.class,
    fallback = DemoFeignFallback.class
)
public interface DemoFeign {


  @GetMapping("/info/{id}")
  public Object info(@PathVariable("id") Integer id) ;


}

服務降級類必須實現對應FeignClient的接口

public class DemoFeignFallback implements DemoFeign {


  public Object info(Integer id) {
    return "default - " + id;
  }
}

  • 服務降級工廠

如果需要訪問觸發回退的原因,可以使用 @FeignClient 內的 fallbackFactory 屬性。

@FeignClient(
    url = "http://localhost:8088/demos", 
    name = "demoService", 
    configuration = DemoFeignConfiguration.class,
    fallbackFactory = DemoFeignFallbackFactory.class,
)
public interface DemoFeign {


  @GetMapping("/info/{id}")
  public Object info(@PathVariable("id") Integer id) ;


}

工廠類

public class DemoFeignFallbackFactory implements FallbackFactory<DemoFeignFallback> {


  static class DemoFeignFallback implements DemoFeign {


    private Throwable cause ;


    public DemoFeignFallback(Throwable cause) {
      this.cause = cause ;
    }


    @Override
    public Object info(Integer id) {
      return "接口調用異常 - " + this.cause.getMessage() ;
    }


  }


  @Override
  public DemoFeignFallback create(Throwable cause) {
    return new DemoFeignFallback(cause) ;
  }
}

  • 緩存支持

如果使用 @EnableCaching 注解,則會創建并注冊一個 CachingCapability Bean,以便 Feign 客戶端識別其接口上的 @Cache* 相關注解:

@FeignClient(
    url = "http://localhost:8088/demos", 
    name = "demoService", 
    configuration = DemoFeignConfiguration.class,
    fallbackFactory = DemoFeignFallbackFactory.class,
)
public interface DemoFeign {


  @GetMapping("/info/{id}")
  @Cacheable(cacheNames = "demo-cache", key = "#id")
  public Object info(@PathVariable("id") Integer id) ;
}

  • Feign繼承支持

Feign 通過單繼承接口支持模板應用程序。這樣就可以將常用操作歸類到方便的基礎接口中。

@FeignClient(
    url = "http://localhost:8088/users", 
    name = "userService"
)
public interface UserService {


  @GetMapping("/{id}")
  User getUser(@PathVariable("id") Long id) ;
}
@FeignClient("users")
public interface UserClient extends UserService {
}

注意:@FeignClient 接口不應在服務器和客戶端之間共享,并且不再支持在類級使用 @RequestMapping 對 @FeignClient 接口進行注解。

  • 請求相應壓縮

你可以考慮為你的 Feign 請求啟用請求或響應 GZIP 壓縮。你可以啟用其中一個屬性:

feign: 
  compression: 
    request
      enabled: true
    response:
      enabled: true

控制壓縮MeidaType類型和最小請求閾值長度

feign:
  compression: 
    request:
      mime-types: text/xml,application/xml,application/json
      min-request-size: 2048

3. 關于響應式客戶端

由于 OpenFeign 項目目前不支持 Spring WebClient 等反應式客戶端,因此 Spring Cloud OpenFeign 也不支持反應式客戶端。

目前官方推薦的響應式庫:feign-reactive

<dependency>
  <groupId>com.playtika.reactivefeign</groupId>
  <artifactId>feign-reactor-webclient</artifactId>
  <version>3.3.0</version>
</dependency>

我目前使用的是3.3.0版本,除了注解適當調整,其它使用基本一致,非常爽。

@ReactiveFeignClient(
    url = "http://localhost:8088/demos", 
    name = "demoReactorFeign", 
    fallback = DemoReactorFeignFallback.class,
    configuration = {DemoReactorFeignConfig.class}
)
public interface DemoReactorFeign {
  @GetMapping("/info/{id}")
  public Mono<Object> info(@PathVariable("id") Integer id) ;
}

總結:

OpenFeign是一個非常有用的工具,它為開發者提供了一種簡單而強大的方式來處理遠程服務調用。通過使用OpenFeign,開發者可以專注于業務邏輯,而無需花費太多精力在復雜的網絡編程細節上。

OpenFeign的聲明式編程風格使得我們能夠以一種高度抽象和簡潔的方式與遠程服務進行交互,它簡化了網絡請求的構建和發送過程,降低了開發的復雜度。

總的來說,Spring Cloud OpenFeign是一個強大而靈活的工具,它可以幫助開發者更高效地構建和維護微服務應用。通過使用OpenFeign,我們可以更好地專注于業務邏輯,而無需擔心網絡調用的實現細節。

完畢!!!

責任編輯:武曉燕 來源: Spring全家桶實戰案例源碼
相關推薦

2023-11-15 08:22:42

Java開發小技巧

2023-12-13 08:28:07

2021-08-30 07:49:33

索引ICP Mysql

2018-09-02 15:43:56

Python代碼編程語言

2023-09-08 08:23:29

Servlet程序MVC

2024-10-21 17:46:54

前端開發

2025-03-17 00:45:00

JavaScriptAPI頁面

2020-07-28 08:26:34

WebSocket瀏覽器

2020-06-12 09:20:33

前端Blob字符串

2009-12-10 09:37:43

2022-10-13 11:48:37

Web共享機制操作系統

2021-02-01 23:23:39

FiddlerCharlesWeb

2011-09-15 17:10:41

2025-05-21 14:08:47

2010-08-23 09:56:09

Java性能監控

2020-10-15 17:35:22

PandasPython開發

2025-05-08 08:59:19

前端技巧

2025-08-18 02:22:00

前端技巧代碼

2025-11-10 01:11:00

前端工具代碼API

2022-11-04 08:19:18

gRPC框架項目
點贊
收藏

51CTO技術棧公眾號

日韩美女中文字幕| 美女性感视频久久| 91福利视频网站| 国产深夜男女无套内射| 国产精品mv在线观看| 国产一区二区日韩| 欧美在线一卡| 99久久久无码国产精品| 91成人免费视频| 日韩中文一区二区| 精品奇米国产一区二区三区| 香港经典三级在线| 成人动漫一区二区三区| 麻豆成人在线播放| 日韩av在线中文字幕| 久久成人精品电影| 日韩伦理在线一区| 欧美疯狂做受xxxx富婆| 美女永久在线网站| 国产精品网曝门| 国产乱子伦精品无码专区| 黄色亚洲免费| 国产精品第七影院| 999久久精品| 一区二区三区美女xx视频| 老司机午夜在线| 色婷婷久久久综合中文字幕| 国产高潮av| 中文一区一区三区高中清不卡| 久久国产精品网| 国产精品乡下勾搭老头1| 亚洲精品在线免费| 久久久久国产一区二区| 国产精品手机在线| 黄色欧美日韩| 国产乱子伦精品| 亚洲精品字幕| 欧美精品一区二区三区四区五区| 亚洲区第一页| 国产美女在线精品免费观看| 欧美a级片网站| 国产主播在线一区| 欧洲激情综合| 成人天堂噜噜噜| 日韩专区精品| 91午夜理伦私人影院| 欧美肥老太太性生活| 成人免费淫片视频软件| 女人色偷偷aa久久天堂| 91嫩草在线| 在线亚洲观看| 深夜福利成人| 国产成人在线网站| 人妻久久久一区二区三区| 粉嫩嫩av羞羞动漫久久久| 国产高清www| 国产日韩欧美a| 九色视频网站| 欧美在线观看18| a篇片在线观看网站| 亚洲国产精品成人精品| 少妇视频一区| 久久精品亚洲一区| 窝窝社区一区二区| 国产精品中文在线| 亚洲日韩成人| 男人的天堂视频在线| 91影院在线观看| 黄色大秀av大片| 在线看一区二区| 国产高清视频色在线www| 久久久精品视频成人| 黄色网一区二区| 亚洲一区二区三区视频| 久久综合九色综合欧美狠狠| 一级特黄妇女高潮| 欧美极品少妇xxxxⅹ高跟鞋| 中文字幕一二三区在线观看| 777久久久精品| 亚洲日本网址| 奇米一区二区三区四区久久| 亚洲午夜电影| 丰满的少妇愉情hd高清果冻传媒| 中文字幕欧美三区| 黄色的视频在线免费观看| 亚洲第一精品久久忘忧草社区| 日日夜夜精品| 亚洲综合精品伊人久久| 韩国三级在线一区| 1024欧美极品| 精品国产伦一区二区三区观看方式| 欧美成人家庭影院| 成人国产亚洲精品a区天堂华泰| 麻豆精品在线看| 调教视频vk| 日韩免费成人网| 日韩欧美国产大片| 欧美亚洲国产视频小说| 久久人人超碰精品| 麻豆免费网站| 欧美日韩一区二区三区免费看| 免费高清在线观看| 日韩欧美成人一区二区| 99久久综合国产精品二区| 亚洲网站在线播放| 伊人春色精品| 久久97精品久久久久久久不卡| 日韩三级不卡| 久久色在线播放| 欧美不卡1区2区3区| 91片在线免费观看| 川上优的av在线一区二区| 精品国产视频在线| 国产精品videosex极品| 天天爽夜夜爽一区二区三区| 精品美女一区二区三区| 精品国产一区探花在线观看| 日韩精品福利片午夜免费观看| 精品美女久久久久久免费| 中文字幕日韩亚洲| 久久久久久久久久久一区| |精品福利一区二区三区| 中文字幕成在线观看| 成人精品在线视频| 中文字幕欧美日本乱码一线二线| 瑟瑟视频在线看| 久久精品五月婷婷| 无吗不卡中文字幕| 伊人久久亚洲| 国产亚洲黄色片| 亚洲国产成人在线播放| 亚洲国产mv| 国产a级片免费观看| 国产一区二区三区三区在线观看| 激情综合电影网| 欧美著名女优| 欧美中文在线免费| 大陆成人av片| 国产夫妻在线| 一级做a爰片久久| 欧美一区二区福利在线| 久久精品欧美一区| 免费观看黄色网| 26uuu久久噜噜噜噜| 国产婷婷精品av在线| 欧美成人三级| 国产日本在线播放| 国产亚洲欧美日韩一区二区| 毛片一区二区三区| 91麻豆国产福利在线观看宅福利| av在线不卡观看| 色爱区综合激月婷婷| 日韩中文欧美| 在线视频2区| 91久久中文字幕| 日韩欧美在线播放| 日韩一区二区在线免费| 欧美vide| 成人在线精品视频| 欧美特黄级在线| 亚洲黄色av| 羞羞电影在线观看www| 色一情一乱一伦一区二区三欧美| 在线播放91灌醉迷j高跟美女 | 久久久99精品免费观看不卡| 亚洲美女炮图| 人妻激情另类乱人伦人妻| 国产偷亚洲偷欧美偷精品| 国产乱色国产精品免费视频| 浪潮色综合久久天堂| 国产freexxxx性播放麻豆| 在线日韩精品视频| 波波电影院一区二区三区| 先锋影音网一区二区| 中文久久久久久| 国产精品va在线播放| 在线观看欧美日本| 日本不卡中文字幕| 亚洲一区二区久久久| 欧美日韩不卡一区二区| 亚洲国产一区在线观看| 国产一区二区精品久久91| 在线精品在线| 国产精品一国产精品| 日本成人网址| 国产三级日本三级在线播放| 欧美成人在线免费| 亚洲激情久久久| 欧美一区日本一区韩国一区| 大片网站久久| chinese偷拍一区二区三区| 久久偷窥视频| 日韩精品免费视频| 91在线播放网址| 久操国产精品| 青青草av免费在线观看| 日本黑人久久| 久久夜色精品国产| 欧美日韩精品国产| 久久精品国产77777蜜臀|