本篇文章為大家展示了SpringCloud中使用Feign時(shí)會(huì)遇到哪些問(wèn)題,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶,將通過(guò)不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名注冊(cè)、雅安服務(wù)器托管、營(yíng)銷軟件、網(wǎng)站建設(shè)、榆樹(shù)網(wǎng)站維護(hù)、網(wǎng)站推廣。
一、FeignClient接口,不能使用@GettingMapping 之類的組合注解
代碼示例:
@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
代碼示例:
@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多參數(shù)的構(gòu)造
如果想要請(qǐng)求microservice-provider-user 服務(wù),并且參數(shù)有多個(gè)例如:http://microservice-provider-user/query-by?id=1&username=張三 要怎么辦呢?
直接使用復(fù)雜對(duì)象:
@FeignClient("microservice-provider-user") public interface UserFeignClient { @RequestMapping(value = "/query-by", method = RequestMethod.GET) public User queryBy(User user); ... }
該請(qǐng)求不會(huì)成功,只要參數(shù)是復(fù)雜對(duì)象,即使指定了是GET方法,feign依然會(huì)以POST方法進(jìn)行發(fā)送請(qǐng)求。
正確的寫法:
寫法1:
@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:
@FeignClient(name = "microservice-provider-user") public interface UserFeignClient { @RequestMapping(value = "/query-by", method = RequestMethod.GET) public ListqueryBy(@RequestParam Map param); }
四、Feign如果想要使用Hystrix Stream,需要做一些額外操作
我們知道Feign本身就是支持Hystrix的,可以直接使用@FeignClient(value = "microservice-provider-user", fallback = XXX.class)
來(lái)指定fallback的類,這個(gè)fallback類集成@FeignClient所標(biāo)注的接口即可。
但是假設(shè)我們需要使用Hystrix Stream進(jìn)行監(jiān)控,默認(rèn)情況下,訪問(wèn)http://IP:PORT/hystrix.stream 是個(gè)404。如何為Feign增加Hystrix Stream支持呢?
需要以下兩步:
第一步:添加依賴,示例:
org.springframework.cloud spring-cloud-starter-hystrix
第二步:在啟動(dòng)類上添加@EnableCircuitBreaker 注解,示例:
@SpringBootApplication @EnableFeignClients @EnableDiscoveryClient @EnableCircuitBreaker public class MovieFeignHystrixApplication { public static void main(String[] args) { SpringApplication.run(MovieFeignHystrixApplication.class, args); } }
這樣修改以后,訪問(wèn)任意的API后,再訪問(wèn)http://IP:PORT/hystrix.stream,就會(huì)展示出一大堆的API監(jiān)控?cái)?shù)據(jù)了。
五、如果需要自定義單個(gè)Feign配置,F(xiàn)eign的@Configuration 注解的類不能與@ComponentScan 的包重疊
如果包重疊,將會(huì)導(dǎo)致所有的Feign Client都會(huì)使用該配置。
六、首次請(qǐng)求失敗
詳見(jiàn):解決Spring Cloud中Feign/Ribbon第一次請(qǐng)求失敗的方法
七、@FeignClient 的屬性注意點(diǎn)
(1) serviceId屬性已經(jīng)失效,盡量使用name屬性。例如:
@FeignClient(serviceId = "microservice-provider-user")
這么寫是不推薦的,應(yīng)寫為:
@FeignClient(name = "microservice-provider-user")
(2) 在使用url屬性時(shí),在老版本的Spring Cloud中,不需要提供name屬性,但是在新版本(例如Brixton、Camden)@FeignClient必須提供name屬性,并且name、url屬性支持占位符。例如:
@FeignClient(name = "${feign.name}", url = "${feign.url}")
上述內(nèi)容就是SpringCloud中使用Feign時(shí)會(huì)遇到哪些問(wèn)題,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。