feign的玩法
Feign
在前面的學(xué)習(xí)中,我們使用了Ribbon的負(fù)載均衡功能,大大簡(jiǎn)化了遠(yuǎn)程調(diào)用時(shí)的代碼:
String user = this.restTemplate.getForObject("http://service-provider/user/" + id, String.class);如果就學(xué)到這里,你可能以后需要編寫類似的大量重復(fù)代碼,格式基本相同,無非參數(shù)不一樣。有沒有更優(yōu)雅的方式,來對(duì)這些代碼再次優(yōu)化呢?
這就是我們接下來要學(xué)的Feign的功能了。
?
簡(jiǎn)介
有道詞典的英文解釋:
為什么叫偽裝?
Feign可以把Rest的請(qǐng)求進(jìn)行隱藏,偽裝成類似SpringMVC的Controller一樣。你不用再自己拼接url,拼接參數(shù)等等操作,一切都交給Feign去做。
項(xiàng)目主頁(yè):https://github.com/OpenFeign/feign
快速入門
改造service-consumer工程
導(dǎo)入依賴
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>開啟Feign功能
我們?cè)趩?dòng)類上,添加注解,開啟Feign功能
@SpringCloudApplication @EnableFeignClients // 開啟feign客戶端 public class ServiceConsumerApplication {public static void main(String[] args) {SpringApplication.run(ServiceConsumerApplication.class, args);} }刪除RestTemplate:feign已經(jīng)自動(dòng)集成了Ribbon負(fù)載均衡的RestTemplate。所以,此處不需要再注冊(cè)RestTemplate。
?
Feign的客戶端
在service-consumer工程中,添加UserClient接口:
?
內(nèi)容:
@FeignClient(value = "service-provider") // 標(biāo)注該類是一個(gè)feign接口 public interface UserClient {@GetMapping("user/{id}")User queryById(@PathVariable("id") Long id); }-
首先這是一個(gè)接口,Feign會(huì)通過動(dòng)態(tài)代理,幫我們生成實(shí)現(xiàn)類。這點(diǎn)跟mybatis的mapper很像
-
@FeignClient,聲明這是一個(gè)Feign客戶端,類似@Mapper注解。同時(shí)通過value屬性指定服務(wù)名稱
-
接口中的定義方法,完全采用SpringMVC的注解,Feign會(huì)根據(jù)注解幫我們生成URL,并訪問獲取結(jié)果
改造原來的調(diào)用邏輯,調(diào)用UserClient接口:
@Controller @RequestMapping("consumer/user") public class UserController {@Autowiredprivate UserClient userClient;@GetMapping@ResponseBodypublic User queryUserById(@RequestParam("id") Long id){User user = this.userClient.queryUserById(id);return user;}}啟動(dòng)測(cè)試
訪問接口:
正常獲取到了結(jié)果。
?
負(fù)載均衡
Feign中本身已經(jīng)集成了Ribbon依賴和自動(dòng)配置:
因此我們不需要額外引入依賴,也不需要再注冊(cè)RestTemplate對(duì)象。
?
Hystrix支持
Feign默認(rèn)也有對(duì)Hystrix的集成:
只不過,默認(rèn)情況下是關(guān)閉的。我們需要通過下面的參數(shù)來開啟:(在service-consumer工程添加配置內(nèi)容)
feign:hystrix:enabled: true # 開啟Feign的熔斷功能但是,Feign中的Fallback配置不像hystrix中那樣簡(jiǎn)單了。
1)首先,我們要定義一個(gè)類UserClientFallback,實(shí)現(xiàn)剛才編寫的UserClient,作為fallback的處理類
@Component public class UserClientFallback implements UserClient {@Overridepublic User queryById(Long id) {User user = new User();user.setUserName("服務(wù)器繁忙,請(qǐng)稍后再試!");return user;} }2)然后在UserFeignClient中,指定剛才編寫的實(shí)現(xiàn)類
@FeignClient(value = "service-provider", fallback = UserClientFallback.class) // 標(biāo)注該類是一個(gè)feign接口 public interface UserClient {@GetMapping("user/{id}")User queryUserById(@PathVariable("id") Long id); }3)重啟測(cè)試:
?
總結(jié)
- 上一篇: hystrix之熔断
- 下一篇: zuul简介