1. 程式人生 > >Spring Cloud中關於Feign的常見問題總結

Spring Cloud中關於Feign的常見問題總結

這篇文章主要給大家介紹了Spring Cloud中關於Feign的常見問題,文中通過示例程式碼介紹的很詳細,需要的朋友可以參考借鑑,下面來一起看看吧。

一、FeignClient介面,不能使用@GettingMapping 之類的組合註解

程式碼示例:

1

2

3

4

5

6

@FeignClient("microservice-provider-user")

public interface UserFeignClient {

@RequestMapping(value = "/simple/{id}", method = RequestMethod.GET)

public User findById(@PathVariable("id") Long id);

...

}

這邊的@RequestMapping(value = "/simple/{id}", method = RequestMethod.GET) 不能寫成@GetMapping("/simple/{id}") 

二、FeignClient介面中,如果使用到@PathVariable ,必須指定其value

程式碼示例:

1

2

3

4

5

6

@FeignClient("microservice-provider-user"

)

public interface UserFeignClient {

@RequestMapping(value = "/simple/{id}", method = RequestMethod.GET)

public User findById(@PathVariable("id") Long id);

...

}

這邊的@PathVariable("id") 中的”id”,不能省略,必須指定。

三、FeignClient多引數的構造

如果想要請求microservice-provider-user 服務,並且引數有多個例如:http://microservice-provider-user/query-by?id=1&username=張三 要怎麼辦呢?

直接使用複雜物件:

1

2

3

4

5

6

@FeignClient("microservice-provider-user")

public interface UserFeignClient {

@RequestMapping(value = "/query-by", method = RequestMethod.GET)

public User queryBy(User user);

...

}

該請求不會成功,只要引數是複雜物件,即使指定了是GET方法,feign依然會以POST方法進行傳送請求。

正確的寫法:

寫法1:

1

2

3

4

5

@FeignClient("microservice-provider-user")

public interface UserFeignClient {

@RequestMapping(value = "/query-by", method = RequestMethod.GET)

public User queryBy(@RequestParam("id")Long id, @RequestParam("username")String username);

}

寫法2:

1

2

3

4

5

@FeignClient(name = "microservice-provider-user")

public interface UserFeignClient {

@RequestMapping(value = "/query-by", method = RequestMethod.GET)

public List<User> queryBy(@RequestParam Map<String, Object> param);

}

四、Feign如果想要使用Hystrix Stream,需要做一些額外操作

我們知道Feign本身就是支援Hystrix的,可以直接使用@FeignClient(value = "microservice-provider-user", fallback = XXX.class) 來指定fallback的類,這個fallback類整合@FeignClient所標註的介面即可。

但是假設我們需要使用Hystrix Stream進行監控,預設情況下,訪問http://IP:PORT/hystrix.stream 是個404。如何為Feign增加Hystrix Stream支援呢?

需要以下兩步:

第一步:新增依賴,示例:

1

2

3

4

5

<!-- 整合hystrix,其實feign中自帶了hystrix,引入該依賴主要是為了使用其中的hystrix-metrics-event-stream,用於dashboard -->

<dependency>

<groupId>org.springframework.cloud</groupId>

<artifactId>spring-cloud-starter-hystrix</artifactId>

</dependency>

第二步:在啟動類上新增@EnableCircuitBreaker 註解,示例:

1

2

3

4

5

6

7

8

9

@SpringBootApplication

@EnableFeignClients

@EnableDiscoveryClient

@EnableCircuitBreaker

public class MovieFeignHystrixApplication {

public static void main(String[] args) {

SpringApplication.run(MovieFeignHystrixApplication.class, args);

}

}

這樣修改以後,訪問任意的API後,再訪問http://IP:PORT/hystrix.stream,就會展示出一大堆的API監控資料了。

五、如果需要自定義單個Feign配置,Feign的@Configuration 註解的類不能與@ComponentScan 的包重疊

如果包重疊,將會導致所有的Feign Client都會使用該配置。

六、首次請求失敗

在Spring Cloud中,Feign和Ribbon在整合了Hystrix後,可能會出現首次呼叫失敗的問題,要如何解決該問題呢?

造成該問題的原因

Hystrix預設的超時時間是1秒,如果超過這個時間尚未響應,將會進入fallback程式碼。而首次請求往往會比較慢(因為Spring的懶載入機制,要例項化一些類),這個響應時間可能就大於1秒了。知道原因後,我們來總結一下解決放你。

解決方案有三種,以feign為例。

方法一
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 5000
該配置是讓Hystrix的超時時間改為5秒

方法二
hystrix.command.default.execution.timeout.enabled: false
該配置,用於禁用Hystrix的超時時間

方法三

feign.hystrix.enabled: false
該配置,用於索性禁用feign的hystrix。該做法除非一些特殊場景,不推薦使用。

總結

以上就是關於Spring Cloud中解決Feign/Ribbon第一次請求失敗的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對指令碼之家的支援。

七、@FeignClient 的屬性注意點

(1) serviceId屬性已經失效,儘量使用name屬性。例如:

1

@FeignClient(serviceId = "microservice-provider-user")

這麼寫是不推薦的,應寫為:

1

@FeignClient(name = "microservice-provider-user")

(2) 在使用url屬性時,在老版本的Spring Cloud中,不需要提供name屬性,但是在新版本(例如Brixton、Camden)@FeignClient必須提供name屬性,並且name、url屬性支援佔位符。例如:

1

@FeignClient(name = "${feign.name}", url = "${feign.url}")

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對指令碼之家的支援。